项目场景:

在使用C++中thread类创建子线程完成相关功能,并且主线程不阻塞直到子线程完成。


问题描述:

子线程的初始化在对象的初始化过程中,并且子线程有自己独立的功能,主线程并不阻塞直到子线程完成对应的功能。
类似代码示例如下:

void task1(std::string msg){
	std::cout << "task1 says: " << msg;
}
int main() {
	std::thread t1(task1, "hello");
	return 0;
}

编译后执行会报如下错误:

terminate called without an active exception
Aborted

原因分析及解决方案:

原因就是创建线程后,主线程立马退出。但是子线程还没执行完,子线程被销毁,此时就会出现上述错误。知道了造成错误的原因,那么解决错误的方法自然而然也就可以得出。

解决方法一:主线程等待子线程完成后退出

C++中提供了join()函数,join()函数就是一个等待线程完成的函数,主线程需要等待子线程运行结束,才可以结束,也就是调用join()方法的线程是子线程。将上述代码改成如下,即不会抛出异常:

void task1(std::string msg){
	std::cout << "task1 says: " << msg;
}
int main() {
	std::thread t1(task1, "hello");
	t1.join();
	return 0;
}

解决方法二:主线程退出并不干预子线程的销毁

C++种提供了detach()函数,detach函数就是让子线程与主线程分离,主线程不再干预子线程的运行,缺点就是主线程无法获取子线程的执行结果,因为主线程此时已经退出。下面的代码可以正常运行,但是不会打印"task1 says hello"。

void task1(std::string msg){
	std::cout << "task1 says: " << msg;
}
int main() {
	std::thread t1(task1, "hello");
	t1.detach();
	return 0;
}

如有错误,希望大家批评指正,日拱一卒,功不唐捐。
参考:https://stackoverflow.com/questions/7381757/c-terminate-called-without-an-active-exception

Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐