Retired Document
Important: This document may not represent best practices for current development. Links to downloads and other resources may no longer be valid.
Developing a JNI Application
When you need to leverage existing C or Objective-C code in a Java application or need to improve the performance of an application by executing critical parts natively instead of on the Java virtual machine, you use the Java Native Interface (JNI). The JNI provides a way for Java code to communicate with C-based libraries.
Project Builder provides a template that facilitates the development of JNI-based applications. For an explanation of the elements of that template, including its targets, see The JNI Application Template.
Creating the “Hello, JNI” Application
The JNI application template provides yet another version of a “Hello, World” application. This one, however, joins the flexibility of Java with the high performance of C code to print the famous greeting on the console. Follow these steps to create a JNI-based application.
Launch Project Builder. It’s located in
/Developer/Applications
.Create a Java JNI application project.
Choose File > New Project, and select Java JNI Application under Java in the template list.
Name the project and choose a location for it.
In the New Java JNI Application pane of the Assistant, enter
Hello_JNI
in the Project Name text input field, click Choose, and choose a location for the project folder.
When done, you should see the Project Builder window, shown in Figure 5-1. The files in red are the project’s products, which haven’t been built.
data:image/s3,"s3://crabby-images/d85cc/d85cc994b478506bd892a5b38447e2ea45556693" alt="The Leverage project in the Project Builder window"
Project Builder generated the source files for the native side and the Java side of the application. They’re shown in Listing 5-1 and Listing 5-2.
Listing 5-1 Leveragejnilib.c
source file in the Leverage project
#include "JNIWrapper.h" |
int shared_function(const char *arg) { |
printf("shared_function called with %s\n", arg); |
return 42; |
} |
JNIEXPORT jint JNICALL Java_JNIWrapper_native_1method(JNIEnv *env, jobject this, jstring arg) { |
/* Convert to UTF8 */ |
const char *argutf = (*env)->GetStringUTFChars(env, arg, JNI_FALSE); |
/* Call into external dylib function */ |
jint rc = shared_function(argutf); |
/* Release created UTF8 string. */ |
(*env)->ReleaseStringUTFChars(env, arg, argutf); |
return rc; |
} |
Listing 5-2 JNIWrapper.java
source file in the Leverage project
import java.util.*; |
public class JNIWrapper { |
static { |
// Ensure native JNI library is loaded. |
System.loadLibrary("Leverage"); |
} |
public JNIWrapper() { |
System.out.println("JNIWrapper instance created"); |
} |
native int native_method(String arg); |
public static void main (String args[]) { |
System.out.println("Started JNIWrapper"); |
JNIWrapper newjni = new JNIWrapper(); |
int result = newjni.native_method("Hello World !"); |
System.out.println("Finished JNIWrapper. Answer is " + result); |
} |
} |
Now, make sure the Leverage target is selected, and build and run the application. Several files appear in the project’s build folder. Because this is a JNI application, in addition to the JAR file containing the Java application, you see a JNI library file, which contains the object file for the native function specified in Leveragejnilib.c
(Figure 5-2). The Header folder contains the JNIWrapper.h
file, which is generated by javah
from the JNIWrapper.class
file.
data:image/s3,"s3://crabby-images/744c3/744c30af1c8129b9ce7f75cf4a706bc75abcd0e2" alt="The build folder of the Leverage project after building the application"
JNI-Based Examples
The developer tools package includes several examples of JNI-based applications, including a Cocoa/Java application located in /Developer/Examples/Java/AppleDemos/CocoaComponent
. Open those projects and examine them to get a glimpse of the power and flexibility that Java and JNI provide.
Copyright © 2003 Apple Computer, Inc. All Rights Reserved. Terms of Use | Privacy Policy | Updated: 2003-10-10