教程来源: mac端使用IDEA和CLion开发JNI Linux gcc编译 jni.h、jni_md.h、jvmti.h找不到原因及解决 IDEA一键快速生成JNI头文件(可直接复制使用) ld: symbol(s) not found for architecture x86_64 clang: error: linker command failed with exit code 1 cannot initialize a parameter of type ‘jboolean *’ (aka ‘unsigned char *’) with an rvalue of type…
一、新建java项目工程
1.1 直接下一步到底
data:image/s3,"s3://crabby-images/f6a9e/f6a9e0e80d6b2a24b63607aaac148d4b9fa8fc2a" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/e198d/e198da0780a3c4ee9ed24e610f8c765281ee151a" alt="在这里插入图片描述"
1.2 新建Java类
data:image/s3,"s3://crabby-images/c7a63/c7a638ecc2ee33d8ed64ead9b6f27814c0c42b28" alt="在这里插入图片描述"
public class HelloJNI {
static{
System.loadLibrary("HelloJNI");
}
public static native void sayHello();
public static void main(String[] args){
HelloJNI.sayHello();
HelloJNI.sayHello();
}
}
1.3 新建外部工具
data:image/s3,"s3://crabby-images/40aac/40aac6ec31b2190158e5ef18f37bc7d9f4162c74" alt="在这里插入图片描述" 为了方便大家输入给出四个参数可以直接复制粘贴使用: 名称:Generate Header File 程序:$JDKPath$/bin/javah 实参:-jni -classpath $OutputPath$ -d ./jni $FileClass$ 工作目录:$ProjectFileDir$
1.4 构建模块
data:image/s3,"s3://crabby-images/a6c1e/a6c1e74fdc4781308e10b739241a32b2a22d9a42" alt="在这里插入图片描述"
1.5 生成头文件
data:image/s3,"s3://crabby-images/9d7c7/9d7c7254a068ab3c3b076726c98e2761cdebda70" alt="在这里插入图片描述"
二、新建C++项目工程
2.1 打开jni文件夹
data:image/s3,"s3://crabby-images/1818f/1818f12d40592fd61e399d5e978d77e1c2ddbd3c" alt="在这里插入图片描述"
2.2 复制gcc编译所需要的 jni.h、jni_md.h、jvmti.h
macOS路径: /Users/suvancheng/Library/Java/JavaVirtualMachines/corretto-1.8.0_312/Contents/Home/include/jni.h /Users/suvancheng/Library/Java/JavaVirtualMachines/corretto-1.8.0_312/Contents/Home/include/darwin/jni_md.h 路径获取方法:打开终端,执行 /usr/libexec/java_home -V
将jni.h、jni_md.h复制到文件夹下 data:image/s3,"s3://crabby-images/851c0/851c0358b6eb6e143841814f53452dbe52c74189" alt="在这里插入图片描述"
2.3 创建HelloJNI.cpp
data:image/s3,"s3://crabby-images/13de9/13de98bb1df2764a4e1c740da5913decb2ee01fc" alt="在这里插入图片描述"
#include <stdio.h>
#include "HelloJNI.h"
JNIEXPORT void JNICALL Java_HelloJNI_sayHello(JNIEnv *env, jclass jc)
{
printf("Hello Native!?? \n ");
}
2.4 生成动态库
gcc HelloJNI.cpp -o libHelloJNI.jnilib -dynamiclib
data:image/s3,"s3://crabby-images/bae9e/bae9e91d53b3e5008f38e1756825a46b6fb906f9" alt="在这里插入图片描述"
三、配置IDEA、运行测试
3.1 添加vm选项
data:image/s3,"s3://crabby-images/5f27c/5f27ca5fa15a5356fadc6cb0e42539c30a473e86" alt="在这里插入图片描述" 在编辑运行配置,选择右上角的Modify options–Add VM options ,添加-Djava.library.path=$ProjectFileDir$/jni data:image/s3,"s3://crabby-images/0ae19/0ae19404948829aad731eef1ce079a2d8bbb4ee1" alt="在这里插入图片描述"
3.2 运行测试
data:image/s3,"s3://crabby-images/9c0a2/9c0a27ca84f66ae9ef6583a9b3c2d3afff73feb1" alt="在这里插入图片描述"
顺利完成
|