javah -jni编译带包的class文件出错

javah -jni编译带包的class文件出错

 

java 的class文件在不在包的问题:

     今天遇到javah -jn生成不了c++的header文件,经过排查,发现我以前编译的java的class文件不带包,所以cmd和java class文件在一个目录下,可以顺利的通过,但是我今天编译的java的class文件带包,所以生成不了c++的header文件。

解决办法:

       cmd退到你要编译的class文件的包的上级目录,然后在编译就能通过了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Android Framework层中,如果需要访问底层的硬件或实现一些高级功能,可以通过自定义JNI来实现。 以下是实现自定义JNI的步骤: 1. 创建Java类和native方法 在Java层的类中声明native方法,该方法的实现将在底层的C/C++代码中完成。例如: ``` public class MyJNI { public native int add(int x, int y); } ``` 2. 生成头文件 在命令行中运行以下命令,生成Java类对应的头文件: ``` javah -classpath [classpath] -jni [package].[class] ``` 其中,[classpath]为Java类所在的classpath,[package].[class]为Java类的完整类名。例如: ``` javah -classpath /path/to/android.jar -jni com.example.MyJNI ``` 3. 编写C/C++代码 在生成的头文件中实现native方法的功能。例如: ``` JNIEXPORT jint JNICALL Java_com_example_MyJNI_add(JNIEnv *env, jobject thiz, jint x, jint y) { return x + y; } ``` 4. 编写Android.mk文件jni目录下创建Android.mk文件,用于编译和链接C/C++代码。例如: ``` LOCAL_PATH := $(call my-dir) include $(CLEAR_VARS) LOCAL_MODULE := myjni LOCAL_SRC_FILES := myjni.c include $(BUILD_SHARED_LIBRARY) ``` 5. 编译和打包 在命令行中运行以下命令,编译和打包生成的so库文件: ``` ndk-build ``` 生成的so库文件将位于libs目录下,可以在应用中通过System.loadLibrary()方法加载并调用自定义JNI。 需要注意的是,自定义JNI需要具备一定的C/C++编程知识和技能,并且需要根据实际需求实现相应的功能。建议在实际操作前先进行测试和调试,以确保功能正常。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值