JNI 使用过程的一些问题处理。



  1. javah 无法访问错误: 无法访问android.app.Activity

 找不到android.app.Activity的类文件

原因  : 需要android 工程编译后bin 目录下有相应的文件.class 才可使用javah 命令。

可以在-classpath参数里指定多个目录,用分号分开,像下面这样,如下:

F:\android\hello-jni>javah -classpath "F:\android\adt-bundle-windows-x86-2013021
9\sdk\platforms\android-14\android.jar;bin/classes" -d ndk -jni com.example.hell

ojni.HelloJni


     2.  错误: 找不到 'com.example.testjnihello.HelloJni' 的类文件
原因是 可能不一定是在bin 下面 ,也可能在bin/classes 文件下
需要android 工程编译后bin 目录下有相应的文件.class 才可使用javah 命令。
F:\android\hello-jni>javah -classpath bin/classes" -d ndk -jni com.example.hell
ojni.HelloJni
     3.  Android NDK: WARNING: APP_PLATFORM android-17 is larger than android:minSdkVersion 8 in   ./AndroidManifest.xml

因为NDK指定的版本与minSdkVersion不一致的问题,这本身只是一个警告,但是在eclipse下就会编译报错,那么如何修复呢?

只需要在你的工程的:Application.mk文件中添加如下代码即可:

[cpp]  view plain  copy
    1. APP_PLATFORM := android-8  

其中8就是指的 minSdkVersion ,根据自己的实际情况进行替换!
4.    Android.mk 文件中的注释使用的是“#”

5. Android NDK: Warning: There are no modules to build in this project

your Android.mk file is missing the macro that tells the ndk to actually build a module. Add this to the end of your file:

include $(BUILD_SHARED_LIBRARY) or BUILD_PACKAGE OR BUILD_STATIC_LIBRARY
6. C++ FILE : USE LOGI(""),  error: undefined reference to 'LOGI'
1)#include
2)#define TAG "testjniHello" // 这个是自定义的LOG的标识
#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG,TAG ,__VA_ARGS__) // 定义LOGD类型
#define LOGI(...) __android_log_print(ANDROID_LOG_INFO,TAG ,__VA_ARGS__) // 定义LOGI类型
#define LOGW(...) __android_log_print(ANDROID_LOG_WARN,TAG ,__VA_ARGS__) // 定义LOGW类型
#define LOGE(...) __android_log_print(ANDROID_LOG_ERROR,TAG ,__VA_ARGS__) // 定义LOGE类型
#define LOGF(...) __android_log_print(ANDROID_LOG_FATAL,TAG ,__VA_ARGS__) // 定义
3) 加上 LOCAL_LDLIBS :=-llog
注意Android.mk里有一行include $(CLEAR_VARS)

必须把LOCAL_LDLIBS :=-llog放在它后面才有用,

你可能感兴趣的:(ndk分享)