很少用的两个函数:
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
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