filmov
tv
LJC: Project Panama. One step closer to native code November 16th 6:00pm
Показать описание
About this event
In the software development world, it's a common thing to reuse existing bits of other programs, and libraries even if they were written in different programming languages. Java and its ecosystem aren't the exceptions, for decades Java developers using the technology available out of the box known as Java Native Interface (JNI) - communication interfaces and binds C/C++ native code to Java applications. Despite seeing JNI too often in many software solutions based on Java and C code at the same time, it still has disadvantages like an extensive toolkit (C/C++ compiler, system header files, etc.) making Java applications fragile to C/C++ errors that may put down the whole JVM.
Project Panama aimed to be a successor to JNI by providing clear APIs that help to bind native code to Java applications without involving a native compiler. It allows Java developers to focus on writing Java code instead of dealing with C/C++ most of the time. In this talk, we will go through almost every aspect of Project Panama related to writing C applications in Java and will do a deep dive into C Application Binary Interface (C ABI) as a core technology behind Project Panama as well as JDK foreign function infrastructure components. We also will cover the first standalone JDK code generating tool and how to build a Java library for your favorite C/C++ library.
Key takeaways for attendees:
JNI is no longer the only JDK technology to build a bridge between Java and native code.
JDK is capable to work with most existing OS platforms and architectures.
Foreign Function & Memory API is the implementation of C ABI.
Native code invocation infrastructure code in Java must be optimized for the best performance.
How jextract can speed up the development.
What are the Project Panama limitations?
What's the state of C++ support?
How to build, package and release Java library out of C library
Speaker Bio
Principal engineer, practicing cloud solution architect, open source enthusiast, and Java developer by nature. Java advocate at Oracle, he’s focused on every technical aspect of Java and Java on the cloud, Kubernetes specialist.
“If you see me busy, I am probably attempting to reinvent the wheel by my own will.”
Tech consultant, blogger, photographer, traveler. Denis is a regular attendee and speaker at OpenStack summits (Atlanta, Austin, Paris, Barcelona, Boston), Java conferences, JUG Meetups, PyCons (Hong Kong, Singapore, Italy), PyLondinium, Decompile.De. Co-author of OpenStack Application development, OpenStack DBaaS (Trove) Essentials.
This event is organised by RecWorks on behalf of the London Java Community.
The London Java Community is sponsored by Jfrog, Snyk, Sonatype, Payara and Octopus Deploy
In the software development world, it's a common thing to reuse existing bits of other programs, and libraries even if they were written in different programming languages. Java and its ecosystem aren't the exceptions, for decades Java developers using the technology available out of the box known as Java Native Interface (JNI) - communication interfaces and binds C/C++ native code to Java applications. Despite seeing JNI too often in many software solutions based on Java and C code at the same time, it still has disadvantages like an extensive toolkit (C/C++ compiler, system header files, etc.) making Java applications fragile to C/C++ errors that may put down the whole JVM.
Project Panama aimed to be a successor to JNI by providing clear APIs that help to bind native code to Java applications without involving a native compiler. It allows Java developers to focus on writing Java code instead of dealing with C/C++ most of the time. In this talk, we will go through almost every aspect of Project Panama related to writing C applications in Java and will do a deep dive into C Application Binary Interface (C ABI) as a core technology behind Project Panama as well as JDK foreign function infrastructure components. We also will cover the first standalone JDK code generating tool and how to build a Java library for your favorite C/C++ library.
Key takeaways for attendees:
JNI is no longer the only JDK technology to build a bridge between Java and native code.
JDK is capable to work with most existing OS platforms and architectures.
Foreign Function & Memory API is the implementation of C ABI.
Native code invocation infrastructure code in Java must be optimized for the best performance.
How jextract can speed up the development.
What are the Project Panama limitations?
What's the state of C++ support?
How to build, package and release Java library out of C library
Speaker Bio
Principal engineer, practicing cloud solution architect, open source enthusiast, and Java developer by nature. Java advocate at Oracle, he’s focused on every technical aspect of Java and Java on the cloud, Kubernetes specialist.
“If you see me busy, I am probably attempting to reinvent the wheel by my own will.”
Tech consultant, blogger, photographer, traveler. Denis is a regular attendee and speaker at OpenStack summits (Atlanta, Austin, Paris, Barcelona, Boston), Java conferences, JUG Meetups, PyCons (Hong Kong, Singapore, Italy), PyLondinium, Decompile.De. Co-author of OpenStack Application development, OpenStack DBaaS (Trove) Essentials.
This event is organised by RecWorks on behalf of the London Java Community.
The London Java Community is sponsored by Jfrog, Snyk, Sonatype, Payara and Octopus Deploy