IntellijIdea开发JNI环境搭建
1.新建普通的Java项⽬
2.⾸先编写包含native⽅法的Java⽂件,后续⽣成.h头⽂件需要该Java⽂件的信息:
package gj.jni4windows;
import java.io.File;
import java.io.IOException;
/**
* Author: areful
* <br>
* need compile dynamic library first: compile *.c/*.cpp source files to hello.dll (Windows) or libhello.so (Unixes)
*/
public class HelloJNI {
private native void sayHello();
static {
// // method 1:
// // add vm args: -Djava.library.path=D:\study\JavaStudy\src\jni
// System.loadLibrary("hello");
// method 2:
try {
String path = new File("").getCanonicalPath() + "\\src\\jni\\";
System.out.println(path);
System.load(path + "hello.dll");
} catch (IOException e) {
e.printStackTrace();
}
}
public static void main(String[] args) {
new HelloJNI().sayHello();
}
}
然后通过JDK的javah命令⽣成C/C++的头⽂件:
javah -classpath .. -d .\src gj.jni4windows.HelloJNI
注意此命令需要“-classpath”指定Java源⽂件路径,作者是在与src同级的jni⽬录下调⽤此命令,因此路径为..⽣成的头⽂件如下:
/* DO NOT EDIT THIS FILE - it is machine generated */
#include <jni.h>
/* Header for class gj_jni4windows_HelloJNI */
#ifndef _Included_gj_jni4windows_HelloJNI
#define _Included_gj_jni4windows_HelloJNI
#ifdef __cplusplus
extern "C" {
#endif
/*
* Class: gj_jni4windows_HelloJNI
* Method: sayHello
* Signature: ()V
*/
JNIEXPORT void JNICALL Java_gj_jni4windows_HelloJNI_sayHello
(JNIEnv *, jobject);
#ifdef __cplusplus
}
#endif
#endif
接下来编写C/C++⽂件:
#include<jni.h>
#include <stdio.h>
#include "gj_jni4windows_HelloJNI.h"
JNIEXPORT void JNICALL Java_gj_jni4windows_HelloJNI_sayHello
(JNIEnv *, jobject) {
printf("Hello World!\n");
return;
}intellijidea
编译(作者使⽤的编译环境是Win7 64bit + TDM-GCC64):
g++ -shared -w -std=gnu11 -c -I"%JAVA_HOME%\include" -I"%JAVA_HOME%\include\win32" src\HelloJNI.c g++ -Wl,--add-stdcall-alias -shared -o hello.dll HelloJNI.o
编译命令也是在jni⽬录下,因此Java代码中加载dll路径也是指定在src\jni。
运⾏:
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论