c++ - 退出后分离的线程是否泄漏内存C++
问题描述
我有一个用例,我必须从自身内部停止线程。所以我想将它分离,一旦调用 stop 方法(这将完成线程的执行)。
那么它在分离后会泄漏内存吗?如果是这样,应该如何处理?
解决方案
除非线程实际退出(例如return
s),否则无法“停止”分离的特定线程,因此这取决于您的意思。至少,这对于标准 C++ 线程是不可能的。
如果你问一个线程是否return
会自动清理资源,答案是否定的——它不会。任何在其析构函数中清理资源的 RAII 对象都将被调用,但任何显式分配的内容都不会被清理,并且需要代码手动执行此操作。
如果您正在考虑类似的东西pthread_cancel
,那么很可能它不会被清理,因为这是一个 C API,并且取消不会插入return
执行析构函数清理的 a。我强烈建议不要做这种事情。
如果从线程“停止”实际上意味着类似std::exit
,那么这取决于您使用的底层操作系统。不会运行析构函数,因此不会执行任何特定的清理代码;然而,在大多数现代操作系统上,任何使用过的资源(如开放内存)都会在程序终止时被清理。但是,有些系统不这样做(通常是专用/嵌入式 RTOS)
使用分离的线程防止任何类型的泄漏的最佳方法是能够在您希望它完成时向它发出信号,并始终使用 RAII 对象以便自动清理。
使用c++20,您实际上可以使用std::stop_token
它,但在此之前,您可以简单地从 a 设计一个同步系统,std::shared_ptr<std::atomic<bool>>
并在线程中将其作为“取消点”进行查询。
推荐阅读
- sql - 计数函数sql
- address-sanitizer - 发生未知地址上的 SEGV 时,如何继续执行地址清理程序?
- kubernetes - kubernetes-fabric8 watch API中的Action ADD是什么意思?
- javascript - 删除 react-dnd 中的可拖动对象
- javascript - 在javascript中将二进制数据编码为字符串
- python - 如何使用 Selenium webdriver 和 Python 抓取所有搜索结果
- tensorflow - tf.profiler 的峰值内存使用量比 nvidia-smi 多得多?
- java - bean xml中的Spring配置方法引用
- java - 使用 OpenId Connect 的多个 Liberty 服务器 SSO
- image-processing - Tensorflow 2.0 sobel_edges 图像格式?