Detaching Threads

本文详细阐述了计算机系统中线程的两种状态:可连接和可分离。解释了可连接线程如何通过其他线程进行回收和终止,以及其内存资源直到被另一个线程回收才释放。相比之下,可分离线程在终止时由系统自动释放内存资源,无需其他线程干预。默认情况下,线程创建为可连接,为避免内存泄漏,应明确通过调用pthreads detach函数进行回收或使其成为可分离线程。

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

At any point in time, a thread is joinable or detached. A joinable thread can be reaped and killed by other
threads. Its memory resources (such as the stack) are not freed until it is reaped by another thread. In
contrast, a detached thread cannot be reaped or killed by other threads. Its memory resources are freed
automatically by the system when it terminates.

By default, threads are created joinable. In order to avoid memory leaks, each joinable thread should either

be explicitly reaped by another thread, or detached by a call to the pthread detach function.


#include <pthread.h>
int pthread_detach(pthread t tid);
returns: 0 if OK, non-zero on error


The pthread detach function detaches the joinable thread tid. Threads can detach themselves by
calling pthread detach with an argument of pthread self().
Even though some of our examples will use joinable threads, there are good reasons to use detached threads
in real programs. For example, a high-performance Web server might create a new peer thread each time
it receives a connection request from a Web browser. Since each connection is handled independently by a
separate thread, it is unnecessary and indeed undesirable for the server to explicitly wait for each peer thread
to terminate. In this case, each peer thread should detach itself before it begins processing the request so
that its memory resources can be reclaimed after it terminates.


摘自《深入理解计算机系统》

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值