1.报错,UnsatisfiedLinkError找不到某个方法:
04-23 01:14:17.440: E/AndroidRuntime(4010): java.lang.UnsatisfiedLinkError: ortp_init
查原因几个小时,java和C中的包名/类名/方法名称,都是一致的,编译也没有错误,调用时就是找不到方法,实在是郁闷,差点怀疑人生。
后来,用ndk的sample/HelloJni测试,这里的jni方法是可以正常调用的,于是在hello-jni.c中添加一个函数:
jint Java_com_example_hellojni_HelloJni_ortp_init( JNIEnv* env,
jobject thiz )
{
return 1001;
}
发现一调用ortp_init()就报上面的错误,怀疑是这个名词造成的,试了N次后,发现去掉下划线就好了:
jint Java_com_example_hellojni_HelloJni_ortpinit( JNIEnv* env,
jobject thiz )
{
return 1001;
}
所以,在jni方法名中,不能出现下划线。