1. 报错:

  1. -20 ::): threadid=: thread exiting with uncaught exception (group=0x4001d400)
  2. -20 ::): FATAL EXCEPTION: GLThread
  3. -20 ::: E/AndroidRuntime(): java.lang.CloneNotSupportedException: Class doesn't implement Cloneable
  4. -20 ::: E/AndroidRuntime():    at java.lang.Object.clone(Object.java:)
  5. -20 ::: E/AndroidRuntime():    at com.jnitest.nativetest(Native Method)

2. 现场说明:

在进行android项目开发时, 想用java代码调用jni的test函数,, 而且再通过c的callCallBack函数, 回调到java的onCallback函数., 发生以上错误.

3. 代码:(这里仅仅列出重要的,关键的代码.)

 java代码:

public class NativeClass {

private static String TAG= "NativeClass";

static {

        System.loadLibrary("test-jni");

    }

public static int onCallBack(int event, int type,String str) {  //回调回来的回调函数

  Log.i(TAG, "onCallBack======= " + event);

  Log.i(TAG, "onCallBack======= " + type);

Log.i(TAG, "onCallBack======= " + str);

return event;

}

public static native int test();  //native函数

c代码:

jobject my_obj;

JNIEnv* my_env;

extern "C" int callCallBack(int event, int type, const char *str) ;

extern "C"

{

//用于调用java的callback

int  callCallBack(int event, int type, const char *str)

{

    int err = 1000;

 jclass objClass = (my_env)->FindClass("com/jnitest/native/NativeClass");

 if(!objClass) {

  return -1;

 }

 //获取并调用java层的onCallBack函数

 jmethodID methodId = (my_env)->GetStaticMethodID(objClass, "onCallBack", "(IILjava/lang/String;)I");

 if (methodId == 0) {

  LOGDV("here can not find method %s\n", "onCallBack");

 } else {

  jstring data = (update_env)->NewStringUTF(str));

  

  err = (my_env)->CallStaticIntMethod(objClass, methodId, event, type, data);

  if(data)  my_env->DeleteLocalRef(data);

 }

my_env->DeleteLocalRef(objClass);

 

 

 return err;

}

//jni native函数.

JNIEXPORT jstring JNICALL

Java_com_jnitest_native_test( JNIEnv* env, jobject thiz,jstring testStr )

{

    my_env = env; //必须保存,用于在回调的时候获取回调函数所在的class.

 my_obj = thiz;  //在本程序中,没实用到这个变量.

    const char *test_char = (env)->GetStringUTFChars(testStr, NULL);

 

 //调用callCallBack

 int i = callCallBack(0,1,test_char);

return (env)->NewStringUTF(test_char);

}

}

測试代码:

maintest.java:

void testFunc() {

String s = NativeClass.test("ssss");

Log.i("jniTest", " testFunc  s = " + s);

}

測试结果:

onCallBack=======0

onCallBack=======1

onCallBack=======ssss

testFunc  s =ssss

4. 分析与 解决:

分析,:

依据错误提示:

1).  有clone相关错误;

2)   就发生在NativeClass的test函数中.

3). 那么, 是哪个类没有进行clone?

或者, 根本就不是clone的原因?

4). NativeClass中,没有数据成员, 理论上讲,就不须要进行克隆.所以,应该不是NativeClass克隆的原因.

5). 在jni的test函数中,有对于my_obj的赋值,会不会是这个变量的赋值导致的呢?

解决:  因为my_obj没实用到(本来赋值后想用的), 并且可能会引起错误,所以,将这个变量的声明和赋值语句都去掉,

再測试,程序正常执行.

5. 总结:

1)  由java调用c时,一定要注意參数的正确传递.

2)  本例展示了怎样用java调用c,再由c调用到java的过程.

3) 本例来源于android程序开发.

Class doesn't implement Cloneable之怪象的更多相关文章

  1. [FindBugs分析记录]Class defines clone() but doesn't implement Cloneable

    官网解释: This class defines a clone() method but the class doesn't implement Cloneable. There are some ...

  2. Java 深拷贝、浅拷贝及Cloneable接口

    Cloneable接口是一个空接口,仅用于标记对象,Cloneable接口里面是没有clone()方法,的clone()方法是Object类里面的方法!默认实现是一个Native方法 protecte ...

  3. 实现 Cloneable 需要注意

    产品Product里面包含BaseInfo对象:Product(productName,companyName,baseinfo)如果implement Cloneable  需要实现   注意强转类 ...

  4. Cloneable注解使用

    使用 clone()方法的类必须 implement Cloneable 如果没有继承,clone()方法会报错 java.lang.CloneNotSupportedException异常

  5. java开发——Cloneable接口、clone()方法和深浅拷贝

    1.实现Cloneable接口表明该类的对象是允许克隆的. 2.允许克隆的意思是:可以调用clone()方法. 3.深拷贝还是浅拷贝,取决于如何重写Object的clone()方法. 4.原对象和克隆 ...

  6. 深拷贝、浅拷贝与Cloneable接口

    深拷贝与浅拷贝 浅拷贝 public class Student implements Cloneable{ Integer a; Integer b; @Override protected Obj ...

  7. Java面试葵花宝典

    面向对象的特征有哪些方面  1. 抽象:抽象就是忽略一个主题中与当前目标2. 无关的那些方面,3. 以便更充分地注意与当前目标4. 有关的方面.抽象并不5. 打算了解全部问题,而6. 只是选择其中的一 ...

  8. java面试题小全

    面向对象的特征有哪些方面   1. 抽象:抽象就是忽略一个主题中与当前目标2. 无关的那些方面,3. 以便更充分地注意与当前目标4. 有关的方面.抽象并不5. 打算了解全部问题,而6. 只是选择其中的 ...

  9. .Net面试葵花宝典

    1.                面向对象的特征有哪些方面    抽象:抽象就是忽略一个主题中与当前目标无关的那些方面,以便更充分地注意与当前目标有关的方面.抽象并不打算了解全部问题,而只是选择其中 ...

随机推荐

  1. 刷题总结——单旋(HNOI2017 bzoj4825)

    题目: Description H 国是一个热爱写代码的国家,那里的人们很小去学校学习写各种各样的数据结构.伸展树(splay)是一种数据 结构,因为代码好写,功能多,效率高,掌握这种数据结构成为了 ...

  2. Agile工作方法

    [工具] Slack https://slack.com/ 看板 https://trello.com/ 其他TBC

  3. P1875 佳佳的魔法药水 (最短路,DP)

    题目链接 Solution 好题. 一开始一直在想怎么蛇皮建图,但是发现一直蛇不出来... 正解是用类似于 dijkstra 的算法对所有点进行松弛. 对于每个元素记录两个值: \(cost\) 代表 ...

  4. FZOJ Problem 2148 Moon Game

                                                                                                  Proble ...

  5. 线程间通过PostMessage通信

    1.查看TMS项目中的相关实例 ::PostMessage(hWnd, WM_USER_MSG_REFRESH_UI, (WPARAM)UMP_REFRESH_MEMBER_INFO, 0); 参考文 ...

  6. Sphinx的GEO距离搜索 [转载]

    近项目用sphinx做地理搜索,可是结果总是不对,明明很近却搜不到 结果检查sphinx源文件: static inline double sphSqr ( double v ) { return v ...

  7. latex beamer 插入代码

    有网友在beamer中使用mcode也就是 listings 输出源代码时遇到如下错误: Runaway argument?! Paragraph ended before \lst@next was ...

  8. 通过房价预测入门Kaggle

    今天看了个新闻,说是中国社会科学院城市发展与环境研究所及社会科学文献出版社共同发布<房地产蓝皮书:中国房地产发展报告No.16(2019)>指出房价上涨7.6%,看得我都坐不住了,这房价上 ...

  9. ‘cnpm' 不是内部或外部命令,也不是可运行的程序

    昨天用npm 安装环境,实在太慢了,就想用cnpm,然后发现提示‘cnpm' 不是内部或外部命令,也不是可运行的程序.  看了很多方法,选择了下面这个,运气好到爆棚,就直接可以用了.其他的方法暂未去了 ...

  10. Ext grid单元格编辑时获取获取Ext.grid.column.Column

    item2.width = 80; //item2.flex = 1; item2.align = 'center'; item2.menuDisabled = true; //禁止显示列头部右侧菜单 ...