Posix编程随笔

本文介绍了 pthread_cleanup_push 和 pthread_cleanup_pop 函数的使用方法及应用场景。通过实例演示如何利用这两个函数确保线程在异常退出时能够正确释放资源,避免死锁等问题。
部署运行你感兴趣的模型镜像
很少用的两个函数:
pthread_cleanup_push((void *)routine, (void *)args);
pthread_cleanup_pop(int execute);
看到这两个函数第一印象应该是push和pop,没错这两个函数的使用和压栈出栈过程一样的。pthread_cleanup_push是指定一个函数routine及其参数args,这个routine在线程退出(不管是执行了pthread_exit还是其它情况)时执行,当然了,前提是没有pthread_cleanup_pop之前,该函数会取消最近一次push的routine,其参数execute为非0时在取消routine之前先执行routine,为0时不执行直接取消routine。

好了,既然明白了他们的意思,那什么时候使用他们呢?举个例子:
当一个线程执行一个pthread_mutext_lock()去锁定一个mutex并成功之后因为异常情况而退出时,那么这个mutex就没有被unlock,其它线程会再也lock锁不定这个mutex,造成其它线程也无法正常运行,这种现象是我们所不愿意看到的,这个时候前面所说的函数就有用武之地了:)在锁定一个mutex之前,先执行:
pthread_cleanup_push((void (*)(void *))pthread_mutex_unlock,  (void *)&mutex);
然后再锁定这个mutex:
pthread_mutex_lock(&mutex);
.
.
其它工作
.
.
.
pthread_mutex_unlock(&mutex);
pthread_cleanup_pop(0);

这样在执行“其它工作”的过程中线程意外退出,则mutex也不会因为它而一直处于lock状态!

2006.6.8

您可能感兴趣的与本文相关的镜像

Dify

Dify

AI应用
Agent编排

Dify 是一款开源的大语言模型(LLM)应用开发平台,它结合了 后端即服务(Backend as a Service) 和LLMOps 的理念,让开发者能快速、高效地构建和部署生产级的生成式AI应用。 它提供了包含模型兼容支持、Prompt 编排界面、RAG 引擎、Agent 框架、工作流编排等核心技术栈,并且提供了易用的界面和API,让技术和非技术人员都能参与到AI应用的开发过程中

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值