安装clion和cmake,MinGW 有32位和64位的,一定要注意位数与jvm匹配,否则会出错。
1.java生成jni的c++头文件
编写一个java类,里面都是native方法
public class HelloApi {
public native String hello();
public native void sayHello();
public native void sayName(String name);
}
通过命令生成JNI的c++头文件(我这里是jdk11)
javac HelloApi -h jni
2.新建c++项目
直接选择创建library就可以了 可以把创建项目生成的library.cpp 和library.h 文件删除,把刚刚用java命令 生成的jni的c++头文件复制到项目中,在创建一个.cpp 文件,用来实现jni头文件里面的方法。
3.修改cmake构建文件(CMakeLists.txt )
主要是吧jni依赖的头文件包含进来。
cmake_minimum_required(VERSION 3.13)
project(jnidll)
set(CMAKE_CXX_STANDARD 14)
include_directories(D:\\soft\\JAVA\\JDK\\include\\win32 D:\\soft\\JAVA\\JDK\\include)
add_library(jnidll SHARED com_wl_HelloApi.cpp com_wl_HelloApi.h)
把jni生成的头文件中的函数实现
#include "com_wl_HelloApi.h"
#include <iostream>
#include <cstdio>
#include <string>
#include <cstring>
using namespace std;
JNIEXPORT jstring JNICALL Java_com_wl_HelloApi_hello
(JNIEnv *env, jobject) {
const char *strContent = "heelo";
char str[] = "欢迎你的到来!";
char *strTemp = (char *) malloc(strlen(strContent) + strlen(str) + 1);
strcpy(strTemp, strContent);
strcat(strTemp, str);
return env->NewStringUTF(strTemp);
}
JNIEXPORT void JNICALL Java_com_wl_HelloApi_sayHello
(JNIEnv *, jobject) {
cout << "hello" << endl;
}
JNIEXPORT void JNICALL Java_com_wl_HelloApi_sayName
(JNIEnv *env, jobject, jstring contentStr) {
const char *strContent = env->GetStringUTFChars(contentStr, JNI_FALSE);
cout << strContent << endl;
}
在build这个c++工程 就会生成.dll 文件 回到java项目,把生成的dll文件可以放到任何位置,把加载dll文件的静态代码块加上。
public class HelloApi {
static {
System.load("F:\\intellijide work\\jniTest\\src\\main\\resources\\libjnidll.dll");
}
public native String hello();
public native void sayHello();
public native void sayName(String name);
}
测试
public class JniDemo {
public static void main(String[] args) {
HelloApi helloApi = new HelloApi();
helloApi.sayHello();
System.out.println(helloApi.hello());
helloApi.sayName("jni测试");
}
}
加载dll文件的时候可能会出现 Can’t find dependent librarie,这是因为你的电脑中没有必须要的dll文件,可以通过dll依赖分析工具看看缺少了那些dll文件。
|