【发布时间】:2017-02-06 11:29:15
【问题描述】:
首先,我没有先验的 C 知识。我正在尝试整理一个线程。这是我的例子。我先调用start,然后在java端做了一些工作后我调用stop
#include <jni.h>
#include <thread>
std::thread LOOPING_THREAD;
bool do_job = false;
//looping func
void looping(int test) {
while (do_job) {
LOGD("Doing job");
}
}
//start
JNIEXPORT jint JNICALL
Java_com_example_start(JNIEnv *env, jobject thiz,) {
LOOPING_THREAD = std::thread(looping, 1);
}
JNIEXPORT jint JNICALL
Java_com_example_stop(JNIEnv *env, jobject thiz) {
do_job= false;
LOOPING_THREAD.join();
return 0;
}
}
以上通常工作正常,但虽然我无法自己重现它,但我在调用后得到关于中止线程的本机崩溃日志
LOOPING_THREAD = std::thread(looping, 1);
例如
#00 pc 00044340 /system/lib/libc.so (tgkill+12)
#01 pc 00041f41 /system/lib/libc.so (pthread_kill+32)
#02 pc 0001ba6f /system/lib/libc.so (raise+10)
#03 pc 00018c11 /system/lib/libc.so (__libc_android_abort+34)
#04 pc 000167d0 /system/lib/libc.so (abort+4)
#05 pc 00010aa3 /data/app/com.app-1/lib/arm/libapp.so (_ZN9__gnu_cxx27__verbose_terminate_handlerEv+230)
#06 pc 0000cfb9 /data/app/com.app-1/lib/arm/libapp.so (_ZN10__cxxabiv111__terminateEPFvvE+4)
#07 pc 0000d0c1 /data/app/com.app-1/lib/arm/libapp.so (_ZSt9terminatev+8)
#08 pc 00008ddb /data/app/com.app-1/lib/arm/libapp.so (_ZNSt6threadaSEOS_+38)
如何防止这种崩溃?我尝试添加互斥锁和解锁以按如下方式运行和停止,但它会导致循环在完成之前挂起一段时间,这在这种情况下是不可接受的。
void looping(int test) {
while (do_job) {
mutex.lock()
LOGD("Doing job");
mutex.unlock()
}
JNIEXPORT jint JNICALL
Java_com_example_stop(JNIEnv *env, jobject thiz) {
mutex.lock()
do_job= false;
mutex.unlock()
return 0;
}
更新
我已经删除了锁,而是在创建线程并让它运行之后,在 JNI start(..) 处使用 detach() 分离线程。然后,在设置 do_job = true 后在 JNI stop(...) 处等待 200 毫秒
这行得通吗?
【问题讨论】:
-
请在您的示例中修复代码缩进。
标签: android c++ multithreading c++11 android-ndk