线程在调用本机调用后旋转失败

时间:2012-03-23 07:19:08

标签: android android-ndk java-native-interface

好吧我的java代码:

private static native void setNativeFiles(mFileDescriptor[] r);
public void setFiles(mFileDescriptor[] files){
    setNativeFiles(files);
}

static class mFileDescriptor{
    private FileDescriptor fd;
    private long offset;
    private long size;

    public FileDescriptor getFd() {
        return fd;
    }
    public void setFd(FileDescriptor fd) {
        this.fd = fd;
    }
    public long getOffset() {
        return offset;
    }
    public void setOffset(long offset) {
        this.offset = offset;
    }
    public long getSize() {
        return size;
    }
    public void setSize(long size) {
        this.size = size;
    }
}

mFileDescriptor是一个内部类btw ...

我的代码:

void Java_com_ultrasound_JNIinterface_setNativeFiles(JNIEnv* env, jclass mclass, jobjectArray arr){
LOGI("Setting Native files");
jclass filedescriptor = env->FindClass("com/ultrasound/JNIinterface/mFileDescriptor");
int length = env->GetArrayLength(arr);
for(int index = 0; index < length; index++)
{
    //jclass mvclass = env->GetObjectClass(obj);
    jmethodID mid = env->GetMethodID(filedescriptor, "getFd", "()Ljava/io/FileDescriptor;");
    jobject temp = env->CallObjectMethod( arr, mid);
    int mvdata0 = reinterpret_cast<int>(&temp);

    mid = env->GetMethodID(filedescriptor, "getOffset", "()L");
    temp = env->CallObjectMethod( arr, mid);
    long mvdata1 = reinterpret_cast<long>(&temp);

    mid = env->GetMethodID(filedescriptor, "getSize", "()L");
    temp = env->CallObjectMethod( arr, mid);
    long mvdata2 = reinterpret_cast<long>(&temp);

    mFileDescriptor * fp;
    switch(index){
    case 0:
        fp = &ch0Descript;
        fp->fd = mvdata0;
        fp->offset = mvdata1;
        fp->size = mvdata2;
        break;
    case 1:
        fp = &ch1Descript;
        fp->fd = mvdata0;
        fp->offset = mvdata1;
        fp->size = mvdata2;
        break;
    case 2:
        fp = &ch2Descript;
        fp->fd = mvdata0;
        fp->offset = mvdata1;
        fp->size = mvdata2;
        break;
    default:
        LOGE("Native file indexing failed");
    }
}
LOGI("Native files set");

}

每当我调用setFiles时,我都会得到这个:

03-23 00:13:11.080: I/(9879): Setting Native files
03-23 00:13:11.080: I/(9879): Right before loop
03-23 00:13:11.080: I/(9879): IN FOR LOOP
03-23 00:13:11.501: W/ActivityManager(175): Activity pause timeout for HistoryRecord{406814b8 com.ultrasound/.UltraSoundJNIActivity}
03-23 00:13:12.241: W/dalvikvm(9879): threadid=10: spin on suspend #1 threadid=1 (pcf=0)
03-23 00:13:12.982: W/dalvikvm(9879): threadid=10: spin on suspend #2 threadid=1 (pcf=0)
03-23 00:13:12.982: I/dalvikvm(9879): "Thread-10" prio=5 tid=10 RUNNABLE
03-23 00:13:12.982: I/dalvikvm(9879):   | group="main" sCount=0 dsCount=0 obj=0x40651440 self=0x136c48
03-23 00:13:12.982: I/dalvikvm(9879):   | sysTid=9892 nice=0 sched=0/0 cgrp=default handle=1279040
03-23 00:13:12.982: I/dalvikvm(9879):   | schedstat=( 1495360 488283 24 )
03-23 00:13:12.982: I/dalvikvm(9879):   at com.ultrasound.JNIinterface$1.run(JNIinterface.java:~31)
03-23 00:13:12.982: I/dalvikvm(9879):   at java.lang.Thread.run(Thread.java:1019)
03-23 00:13:12.982: I/dalvikvm(9879): "main" prio=5 tid=1 RUNNABLE
03-23 00:13:12.982: I/dalvikvm(9879):   | group="main" sCount=1 dsCount=0 obj=0x40161190 self=0xce68
03-23 00:13:12.982: I/dalvikvm(9879):   | sysTid=9879 nice=0 sched=0/0 cgrp=default handle=-1345002432
03-23 00:13:12.982: I/dalvikvm(9879):   | schedstat=( 64514163 45135496 61 )
03-23 00:13:12.992: I/dalvikvm(9879):   at com.ultrasound.JNIinterface.setNativeFiles(Native Method)
03-23 00:13:12.992: I/dalvikvm(9879):   at com.ultrasound.JNIinterface.setFiles(JNIinterface.java:105)
03-23 00:13:12.992: I/dalvikvm(9879):   at com.ultrasound.UltraSoundJNIActivity.onCreate(UltraSoundJNIActivity.java:59)
03-23 00:13:12.992: I/dalvikvm(9879):   at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
03-23 00:13:12.992: I/dalvikvm(9879):   at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1722)
03-23 00:13:12.992: I/dalvikvm(9879):   at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1784)
03-23 00:13:12.992: I/dalvikvm(9879):   at android.app.ActivityThread.access$1500(ActivityThread.java:123)
03-23 00:13:12.992: I/dalvikvm(9879):   at android.app.ActivityThread$H.handleMessage(ActivityThread.java:939)
03-23 00:13:12.992: I/dalvikvm(9879):   at android.os.Handler.dispatchMessage(Handler.java:99)
03-23 00:13:12.992: I/dalvikvm(9879):   at android.os.Looper.loop(Looper.java:130)
03-23 00:13:12.992: I/dalvikvm(9879):   at android.app.ActivityThread.main(ActivityThread.java:3835)
03-23 00:13:12.992: I/dalvikvm(9879):   at java.lang.reflect.Method.invokeNative(Native Method)
03-23 00:13:12.992: I/dalvikvm(9879):   at java.lang.reflect.Method.invoke(Method.java:507)
03-23 00:13:12.992: I/dalvikvm(9879):   at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:847)
03-23 00:13:12.992: I/dalvikvm(9879):   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:605)
03-23 00:13:12.992: I/dalvikvm(9879):   at dalvik.system.NativeStart.main(Native Method)
03-23 00:13:13.743: W/dalvikvm(9879): threadid=10: spin on suspend #3 threadid=1 (pcf=0)
03-23 00:13:13.743: I/dalvikvm(9879): "Thread-10" prio=5 tid=10 RUNNABLE

最终导致&#34; Fatal spin-on-suspend:倾销线程&#34;

我认为它是getObjectMethod调用,因为我在for循环之前和第一个数据之后放入了一个日志。任何帮助?

1 个答案:

答案 0 :(得分:1)

您的代码有几个问题:

  1. com/ultrasound/JNIinterface/mFileDescriptor - &gt; com/ultrasound/JNIinterface$mFileDescriptor

  2. 将从getFd返回的作业的地址(!)转换为long的代码段错误

  3. {li>

    ()L中的getOffsetgetSize方法必须为()J

    必须使用
  4. CallLongMethod代替CallObjectMethod

  5. temp不需要,CallLongMethod的结果应直接分配给mvdata变量(必须为jlong类型)

    < / LI>