Posix编程随笔

本文介绍了 pthread_cleanup_push 和 pthread_cleanup_pop 函数的使用方法及应用场景。通过实例演示如何利用这两个函数确保线程在异常退出时能够正确释放资源,避免死锁等问题。
摘要由CSDN通过智能技术生成
很少用的两个函数:
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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值