Click here to Skip to main content
Click here to Skip to main content

JNI Basics - 1

, 10 Sep 2002
Rate this:
Please Sign up or sign in to vote.
Calling native functions which are written in C or C++ from Java, using JNI.

Introduction

In this tutorial, I will try to explain how to call native functions which are written in C or C++ from Java, using JNI.

What is JNI

JNI is an acronym of Java Native Interface. Using JNI, we can call functions which are written in other languages from Java. Advantages and disadvantages of this method are as follows:

Advantages:

  1. You can use your existing library which was previously written in another language.
  2. You can call Windows API functions.
  3. For the sake of execution speed.
  4. You can call API functions of some server product which is in C or C++, from Java client.

Disadvantages:

  1. You can’t say "write once run anywhere".
  2. Difficult to debug runtime error in native code.
  3. Potential security risk.
  4. You can’t call it from Applets.

Here we will try to call the MFC function AfxMessageBox() from Java. Our function in C++ will take no arguments and will not return any value.

//Test1.java
class Test1
{
    static
    {
        System.loadLibrary("TestDll");
    }
    public static void main(String ar[])
    {
        System.out.println("Hello world from Java");
        Test1 t=new Test1();
        t.inDll();
    }
    public native void inDll();
}

In static block, we are loading a DLL named TestDll.dll which should be placed in <WINDIR>/SYSTEM32 directory. I am not saying you cannot put this DLL in other directories, you can, but then you will have to register that path in JVM. Here you can call another method as well, instead of loadLibrary().

System.load(“c://winnt//system32//TestDll.dll”);

I think load() method is better as far as usage is concerned because you can easily place your DLL in any directory.

public native void inDll();

As you can guess, this native keyword specifies that inDll() is a native function which is implemented in the library. Also noticeable, there is no implementation. When we call this function in our code, JVM will look for the function in the loaded DLL (due to static block, DLL will be loaded immediately after the loading of the class) and then call that function. Otherwise it will throw java.lang.UnsatisfiedLinkError exception.

Compile this class normally. Now we will need to generate header file of this class.

You can use javah.exe utility which is included with JDK.

Javah -jni Test1

Header file is generated in current directory with the name Test1.h. Keep this header file safe as we will use this soon.

Now we are going to write a DLL which will contain the implementation of our native function. I have chosen MFC AppWizard (DLL) in project and named my project: TestDll.

Include your class header file which was generated previously using javah.exe in TestDll.h.

Copy following line from Test1.h and paste it at the end of TestDll.h.

JNIEXPORT void JNICALL Java_Test1_inDll(JNIEnv *, jobject);

Change this line to:

JNIEXPORT void JNICALL Java_Test1_inDll(JNIEnv *env, jobject obj)
{
    AfxMessageBox("Hello World from dll");
}

Compile this DLL, you will get an error from compiler because compiler was unable to find jni.h file which is included in Test1.h. So include the following two directories in IDE settings.

  • <Drive>:\<JDK Directory>\include
  • <Drive>:\<JDK Directory>\include\win32

Go to Project/Settings, on C/C++ tab, go to Project option, insert following lines at the end:

/I "<Drive>:\<JDK Directory>\include "
/I "<Drive>:\<JDK Directory>\include\win32"

Now compile and generate your DLL, put newly created DLL in system32 directory and then run your class file. It should work properly. If you receive an error like UnsatisfiedLinkError, then recheck your procedure. If you are using any IDE, then try using command prompt. Hope it will work.

In this tutorial, I have tried to explain the basics of JNI. I will write a second tutorial of the series soon in which I will explain how to pass parameters to native functions and return something, along with a practical example.

Waiting for your comments and questions.

License

This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found here

Share

About the Author

Irfan Dawood
Web Developer
Pakistan Pakistan
Irfan Dawood is the junior year student at Department of Computer Science, University of Karachi. His interest includes programming in C++ and Java.

Comments and Discussions

 
Generalwithout JNI Pinmemberheinrichrohwer7-Jul-05 5:22 
Questioncan java access VB.NET .dlls? PinmemberAbhishek Tiwari8-Apr-05 23:47 
AnswerRe: can java access VB.NET .dlls? PinsussAnonymous24-May-05 4:44 
GeneralRe: can java access VB.NET .dlls? PinsussAbhishek Tiwari24-May-05 22:33 
GeneralBufferedImage to vtkSource PinsussPythonian29-Mar-05 22:08 
GeneralJava code executed before nattive Pinmemberchristophek22-Feb-05 1:22 
GeneralRe: Java code executed before nattive PinsussAnonymous14-Sep-05 14:47 
GeneralRe: Java code executed before nattive Pinmemberpickson20-Mar-07 5:08 
GeneralError in javah PinsussLucas Ferst29-Oct-04 8:01 
GeneralRe: Error in javah Pinmemberjan larsen8-Nov-04 22:50 
GeneralExcecution an EXE file Pinsusshashmi13-Apr-04 0:01 
GeneralJava with OPenGl Pinmemberprabu_univ2-Mar-04 21:55 
GeneralRe: Java with OPenGl PinsussAnonymous25-May-04 0:36 
Generalcodeproject for Java PinmemberEdelweiss18-Dec-03 7:46 
GeneralRe: codeproject for Java PinsussAnonymous13-Jan-04 4:08 
GeneralCalling Java from cpp PinsussAnonymous16-Dec-03 21:17 
GeneralRe: Calling Java from cpp Pinsussanonymous29-Dec-03 23:34 
GeneralRe: Calling Java from cpp PinsussAnonymous21-Mar-04 16:06 
GeneralRe: Calling Java from cpp PinsussMaycol18-Aug-04 11:37 
GeneralIt does not work for me PinmemberWilfried_Garnier29-May-03 8:50 
GeneralRe: It does not work for me Pinmemberjan larsen8-Nov-04 22:58 
GeneralRe: It does not work for me PinsussAnonymous17-Nov-04 9:05 
GeneralRe: It does not work for me Pinmemberjan larsen17-Nov-04 20:33 
QuestionWhat about the other side of the native interface? PinmemberAgyklon22-Sep-02 7:56 
AnswerRe: What about the other side of the native interface? PinmemberIrfan Dawood22-Sep-02 11:05 
GeneralRe: What about the other side of the native interface? Pinsussanonymous22-Sep-02 21:44 
GeneralExcellent Article-More Please-Paul...good comments PinsussAnonymous12-Sep-02 6:04 
GeneralDisadvantages... PinmemberPaul Selormey11-Sep-02 15:49 
GeneralRe: Disadvantages... PinmemberIrfan Dawood12-Sep-02 10:58 
GeneralRe: Disadvantages... PinsussAnonymous8-Mar-05 0:05 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.

| Advertise | Privacy | Terms of Use | Mobile
Web03 | 2.8.141216.1 | Last Updated 11 Sep 2002
Article Copyright 2002 by Irfan Dawood
Everything else Copyright © CodeProject, 1999-2014
Layout: fixed | fluid