(g_jvm)->AttachCurrentThread(&env, NULL) 后使用 (g_jvm)->DetachCurrentThread();程序报错

本文探讨了在Java线程中不当使用AttachCurrentThread及DetachCurrentThread方法导致的问题,并提供了正确的JNIEnv获取方式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

(g_jvm)->AttachCurrentThread(&env, NULL)  后使用 (g_jvm)->DetachCurrentThread();程序报错

ERROR: detaching thread with interp frames (count=13)

 

 

在java线程中不能使用AttachCurrentThread、DetachCurrentThread方法来获取JNIEnv。
调用DetachCurrentThread函数的地方在java线程中,即在java调用C++代码时在C++代码中调用了AttachCurrentThread方法来获取JNIEnv,此时JNIEnv已经通过参数传递进来,你不需要再次AttachCurrentThread来获取。在释放时就会报错。

 

int status;
JNIEnv *env;
bool isAttached = false;
status = g_jvm->GetEnv((void**)&env, JNI_VERSION_1_6);
if(status < 0)
{
  g_jvm->AttachCurrentThread(&env, NULL);//将当前线程注册到虚拟机中.
  isAttached = true;
}

env->CallVoidMethod(g_obj, receiveSendLogInInfo);

if(isAttached)
g_jvm->DetachCurrentThread();

转载于:https://www.cnblogs.com/fyqds/p/5354989.html

那还是先不使用了,就用裸指针吧。void *open_media(void *argv) { __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "open_media xxxxxxxxxx"); ThreadData *data = static_cast<ThreadData *>(argv); const char *rurl = data->url; std::string cstr = std::string(data->cameraId); int cameraId = std::stoi(cstr); std::string istr = std::string(data->indexStr); __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "open_media xxxxxxxxxx %s", istr.c_str()); int index = std::stoi(istr); __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "open_media %d %s %i", cameraId, rurl, index); int retries = 0; while (retries < MAX_RETRIES) { cv::VideoCapture stream1(rurl, cv::CAP_FFMPEG); // 检查流是否打开 if (!stream1.isOpened()) { __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "Cannot open RTSP stream!"); std::cerr << "无法打开 RTSP 流,尝试第 " << retries + 1 << " 次重连..." << std::endl; retries++; std::this_thread::sleep_for(std::chrono::seconds(RETRY_INTERVAL)); continue; } __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "open success"); cv::Mat frame; int num = 0; setFrameSize(frameSizeMap,cameraId,frame); while (true) { num++; // if (simulateNetworkIssue()) { // __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "模拟网络问题,断流..."); // // 模拟断流一段时间 // std::this_thread::sleep_for(std::chrono::seconds(5)); // continue; // } // 读取每一帧 // 如果没有读取到帧,退出循环 if (!stream1.read(frame)) { // 释放旧连接 stream1.release(); // 添加时间戳避免缓存 std::string new_url = std::string(rurl) + "?timestamp=" + std::to_string(time(0)); // 重新初始化 if (!stream1.open(new_url, cv::CAP_FFMPEG)) { __LOG_PRINT(ANDROID_LOG_ERROR, "rtsp", "重连失败 %d", cameraId); // 失败时增加延迟 std::this_thread::sleep_for(std::chrono::milliseconds(1000)); retries++; break; } setFrameSize(frameSizeMap,cameraId,frame); __LOG_PRINT(ANDROID_LOG_INFO, "rtsp", "重连成功 %d,第%d次重连", cameraId,retries); } screenShot(num,cameraId,index,frame); } stream1.release(); } // JNIEnv *env; // JavaVM* vm = GetJniEnv(&env); // 需要实现获取JNIEnv的方法 // env->ReleaseStringUTFChars((jstring)data->url_global_ref, data->url); // env->ReleaseStringUTFChars((jstring)data->cameraId_global_ref, data->cameraId); // env->DeleteGlobalRef(data->url_global_ref); // env->DeleteGlobalRef(data->cameraId_global_ref); delete data; return nullptr; }这个函数怎么优化呢?使用裸指针的话
03-21
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值