当在一个线程里面调用AttachCurrentThread后,如果不需要用的时候一定要DetachCurrentThread,否则线程无法正常退出。
static JNIEnv *Adapter_GetEnv()
{
int status;
JNIEnv *envnow = NULL;
status = (*g_JavaVM)->GetEnv(g_JavaVM,(void **) &envnow, JNI_VERSION_1_4);
if(status < 0)
{
status = (*g_JavaVM)->AttachCurrentThread(g_JavaVM,&envnow, NULL);
if(status < 0)
{
return NULL;
}
g_bAttatedT = TRUE;
}
return envnow;
}
static void DetachCurrent()
{
if(g_bAttatedT)
{
(*g_JavaVM)->DetachCurrentThread(g_JavaVM);
}
}
07-24 15:02:23.874: DEBUG/dalvikvm(4932): threadid=9: thread exiting, not yet detached (count=0)
07-24 15:02:23.874: DEBUG/dalvikvm(4932): threadid=9: thread exiting, not yet detached (count=1)
07-24 15:02:23.874: ERROR/dalvikvm(4932): threadid=9: native thread exited without detaching
07-24 15:02:23.874: ERROR/dalvikvm(4932): VM aborting