对于循环原因:VM中止 - 致命信号6(SIGABRT)代码= -6

时间:2015-05-08 08:25:21

标签: java android opencv android-ndk

我不知道为什么会抛出这个错误。只有在使用循环时,应用程序才会崩溃。我正在导入一个ArrayList< ArrayList<点> >进入ndk。我无法使用opencv在视频处理中打开ndk中的视频文件,因此我在java端获得javacv的位置(我一般都是android新手,我找不到更优雅的方法)

外部阵列的长度为10(最大值为50),内部的长度为变化的长度(200 - 500)

我最初认为可能是因为android中的内存限制。我现在相信它不可能是因为我运行了一个迭代10次的空循环。它给了我同样的错误。我不明白这个错误意味着什么。

我是android新手。有人可以帮我吗?应该怎么做呢?我很感激任何和所有的建议。提前致谢!

  

CODE:

    // Class totd to get obj arraylist
    jclass totd = env -> FindClass ("java/util/ArrayList");

    //Methods in totd
    jmethodID totd_get = env-> GetMethodID (totd, "get", "(I)Ljava/lang/Object;");
    jmethodID totd_size = env-> GetMethodID (totd, "size", "()I");

    //Get length of ArrayList

jint totd_len = env-> CallIntMethod (totdat,totd_size);
//start loop for each frame process data:
jint i;
vector<vector<Point> > totalpnts;
for (i=0;i<=totd_len;i++){

    //Get postion data for current frame
    jobject fd = env-> CallObjectMethod (totdat,totd_get,i);
    jclass curd = env-> FindClass ("java/util/ArrayList");
    //Get methods of inner array
    jmethodID curd_get = env-> GetMethodID (curd, "get", "(I)Ljava/lang/Object;");
    jmethodID curd_size = env-> GetMethodID (curd, "size", "()I");
    //Get no. of objects found
    jint objcnt = env-> CallIntMethod (fd,curd_size);
    //Extract data from point
    jlong j = 0;
    vector<Point> framepnts;
    //for(j = 0; j <= objcnt ; j++){
        //Id objlist
        jobject ptxy = env-> CallObjectMethod (fd,curd_get,j);
        jclass pnt = env-> GetObjectClass(ptxy);
        jmethodID constr = env->GetMethodID(pnt, "<init>", "(II)V");
        jfieldID fix = env->GetFieldID(pnt, "x", "I");
        jfieldID fiy = env->GetFieldID(pnt, "y", "I");

        Point xy;
        xy.x = env-> GetIntField(ptxy,fix);
        xy.y = env-> GetIntField(ptxy,fiy);
        framepnts.push_back(xy);

    //}


    totalpnts.push_back(framepnts);


}
  

ERROR:

05-08 13:30:38.593: E/dalvikvm(17064): VM aborting
05-08 13:30:38.595: A/libc(17064): Fatal signal 6 (SIGABRT) at 0x000042a8 (code=-6), thread 17064 (st.trackerproto)

1 个答案:

答案 0 :(得分:0)

我不是来自NDK / C ++世界,而是I know that debugging in NDK world is a complicated task。从java端你总是会得到Fatal signal N (SIGABRT)(无论在NDK层上发生什么),这意味着你的C ++代码中会发生一些错误。但你不会知道它是什么样的错误(但是N值可能会像6或11那样不同),因为它的Java并不知道为什么。你认为循环是一个问题,但你不确定,也许它发生在循环之后或之前或之内。它确实是你的C ++代码的错误。
另请参阅Debugging Android NDK native apps