android Jni开发DetachCurrentThread使用报错

jiudanine1111 2014-10-11 11:33:11
(g_jvm)->AttachCurrentThread(&env, NULL) != JNI_OK 后使用 (g_jvm)->DetachCurrentThread();程序报错
log如下
E/dalvikvm(6848): ERROR: detaching thread with interp frames (count=13)
I/dalvikvm(6848): "main" prio=5 tid=1 RUNNABLE
I/dalvikvm(6848): | group="main" sCount=0 dsCount=0 obj=0x40eb24c0 self=0x7d0788
I/dalvikvm(6848): | sysTid=6848 nice=0 sched=0/0 cgrp=default handle=1074890076
I/dalvikvm(6848): | schedstat=( 381818920 438359929 2441 ) utm=26 stm=12 core=0
I/dalvikvm(6848): at com.shorigo.libs.Common.Login(Native Method)
。。。
I/dalvikvm(6848): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:809)
I/dalvikvm(6848): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:576)
I/dalvikvm(6848): at dalvik.system.NativeStart.main(Native Method)
E/dalvikvm(6848): VM aborting
A/libc(6848): Fatal signal 11 (SIGSEGV) at 0xdeadd00d (code=1)求高手解答
...全文
836 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
Birds2018 2014-11-03
  • 打赏
  • 举报
回复

void *run_task(void *args) { //线程需要执行的东西  
    JNIEnv* env = NULL;  
      
    int n = (*jvm1)->AttachCurrentThread(jvm1,&env, NULL); //从jvm中获取到JNIEnv  
    if (n == 0) {  
          
        jstring msg = (*env)->NewStringUTF(env,"Yes Thread Running.");  
        (*env)->CallVoidMethod(env, obj1, mid1, msg); //回调JAVA层Callback类中的方法  
        (*env)->DeleteGlobalRef(env,obj1); //删除引用  
        (*jvm1)->DetachCurrentThread(jvm1); //这个一定要调用,否则报错,意在取消线程与jvm关联  
    }  
    LOGI("44");  
}  
Birds2018 2014-11-03
  • 打赏
  • 举报
回复
http://blog.csdn.net/birdsaction/article/details/17859395 我以前在JNI中使用过线程,不知道是否和你们用的一样。
htoall 2014-11-03
  • 打赏
  • 举报
回复
我刚才也碰到这个问题。 查了一些资料,得到的结论是在java线程中不能使用AttachCurrentThread、DetachCurrentThread方法来获取JNIEnv。 估计你调用DetachCurrentThread函数的地方在java线程中,即在java调用C++代码时在C++代码中调用了AttachCurrentThread方法来获取JNIEnv,此时JNIEnv已经通过参数传递进来,你不需要再次AttachCurrentThread来获取。在释放时就会报错。 我使用的方法是通过下面的函数来获取JNIEnv,还没有严格经过验证,仅供参考。 typedef enum _GET_JNIENV_STATUS{ GET_FAIL = 0, GET_SUCCES_NOATTACH, GET_SUCCES_ATTCH, }Get_JNIEnv_Status; static Get_JNIEnv_Status getJNIEnv(JNIEnv *env) { Get_JNIEnv_Status GetStatus = GET_FAIL; int status = myVm->GetEnv((void **) &env, JNI_VERSION_1_4); if(status < 0) { LOGD("callback_handler:failed to get JNI environment assuming native thread"); status = myVm->AttachCurrentThread(&env, NULL); if(status < 0) { LOGE("callback_handler: failed to attach current thread"); return GetStatus; } GetStatus = GET_SUCCES_ATTCH; } else { GetStatus = GET_SUCCES_NOATTACH; } return GetStatus; } 当返回值为GET_SUCCES_ATTCH时,需要调用DetachCurrentThread来释放资源。
荔枝别闹了 2014-10-11
  • 打赏
  • 举报
回复
jni不熟悉
jiudanine1111 2014-10-11
  • 打赏
  • 举报
回复
我是完全的新手,求助啊
本课程以2021年度大数据技术学习为背景,重点围绕Spark 3.0框架展开系统讲解。课程内容基于2020年9月官方正式发布的稳定版本Spark 3.0.1进行设计,确保所学技术紧跟行业前沿。整个教学体系划分为九个核心模块,涵盖从基础到高级的完整知识路径。 首先从Spark集群环境部署与配置入手,奠定实际操作基础。随后深入剖析Spark Core核心原理与编程模型,掌握分布式计算基础。课程进一步延伸至实时数据处理领域,系统讲解Spark Streaming流式计算框架及其应用场景。 在数据查询与分析部分,重点介绍Spark SQL模块,学习结构化数据处理方法。同时结合Structured Streaming技术,探讨现代流批一体架构的实现方式。通过综合实战案例,演示如何将各模块知识融会贯通,解决复杂业务场景中的数据处理问题。 为适应多样化开发需求,课程专门设置多语言编程章节,展示Scala、Python、Java等不同语言在Spark生态中的开发模式。针对Spark 3.0版本革新,详细解读其在性能优化、API改进及功能增强方面的最新特性。最后部分聚焦系统性能调优方法论,包括资源配置、执行计划优化等进阶内容,全面提升分布式系统运维能力。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
【GA-ELM预测】基于遗传算法优化极限学习机的单维时间序列预测研究(Matlab代码实现)内容概要:本文研究基于遗传算法(GA)优化极限学习机(ELM)的单维时间序列预测方法,提出了一种结合智能优化算法与快速学习模型的预测框架。通过遗传算法优化ELM的关键参数(如输入权重和偏置),克服传统ELM随机赋值带来的不稳定性和精度局限,提升模型泛化能力与预测准确性。文中以Matlab代码实现整个算法流程,涵盖数据预处理、模型训练、参数优化及结果可视化等环节,适用于风电、负荷、交通流等单变量时间序列的短期预测场景。; 适合人群:具备一定Matlab编程基础,熟悉基本机器学习模型(如神经网络)的高校研究生、科研人员及工程技术人员,尤其适合从事时间序列预测、智能算法优化等相关领域的研究人员; 使用场景及目标:①解决传统ELM模型因随机初始化导致的性能波动问题;②实现高精度单变量时间序列预测,应用于能源、交通、金融等领域;③为智能优化算法与浅层神经网络结合提供可复现的技术方案; 阅读建议:建议读者结合提供的Matlab代码进行实践操作,重点关注遗传算法的编码方式、适应度函数设计以及ELM参数优化过程,通过调整种群规模、交叉变异概率等参数深入理解算法性能影响机制,并尝试将其迁移至其他预测任务中验证有效性。

80,479

社区成员

发帖
与我相关
我的任务
社区描述
移动平台 Android
androidandroid-studioandroidx 技术论坛(原bbs)
社区管理员
  • Android
  • yechaoa
  • 失落夏天
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧