第一个jni实例及简单查看报错

本文详细介绍如何在Java中声明并调用JNI方法,包括生成头文件、编写C/C++代码、生成SO库及在Java中调用的过程。同时,提供解决常见错误的方法,如查看log日志和使用ndk-stack进行错误定位。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

写关于jni方面的文章,仅仅只是为了做个记录而已,因为自己对于jni方面的知识很少有接触,所以都比较浅,只是闲来,学习记录一下!

java调用jni方法,获取返回值

第一步:在java中声明native方法
如下:
public static native String getJniData();

第二步:生成 声明了native方法的头文件
在as工具Terminal下 输入命令 注意输入的路径
F:\asProject\app\src\main\java>javah -d …/jni com.example.a13940.myapplication.MyFirstJni

第三步:新建一个.cpp和.h文件 ,并在cpp文件中引用生成的头文件 和重新写入生成的native方法,如下图1和图2
生成图片的路径变化

First.cpp文件内容
特别注意:#include里面文件路径的书写

#include "com_example_a13940_myapplication_MyFirstJni.h"
JNIEXPORT jstring JNICALL Java_com_example_a13940_myapplication_MyFirstJni_getJniData
  (JNIEnv * env, jclass jcls){
    return env->NewStringUTF("FORM C DATA");
  }

第四步:生成so文件和引用so库
在build.gradle文件中配置生成so库的名称和平台信息
在MyFirstJni中配置加载so库

public class MyFirstJni {
//加载so库
    static {
        System.loadLibrary("firstC");
    }

//定义navie方法
    public static native String getJniData();
}

第五步:最后获取jni层返回的数据
String data = MyFirstJni.getJniData();
则data = “FROM C DATA”;

最后说明一下,生成的so文件的路径为:当前项目下的
\app\build\intermediates\ndk\debug\obj\local

知道了写简单的jni 就要知道怎么查看简单的报错
查看log日志 adb logcat
通过ndk-stack 查看报错日志:
完整命令如下:
adb logcat | ndk-stack -sym so文件的路径
ndk-stack

通过addline 查看报错日志:
在这里插入图片描述
以上是一个小小的demo,后续持续更新

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值