一般情況下,線程在其主函數退出時自動終止,但同時也可以因為接收到另一個線程發來的取消請求而終止.
線程取消的方法是 向目標線程發出一個cancel信號,但如何處理cancel信號則是由目標線程自己決定,或者忽略,或者立即終止,或者繼續運行到cancelation-point(取消點),由不通的cancellation狀態決定.
竭誠接收到cancel信號的默認處理是繼續運行到取消點,也就是說攝制一個canceled狀態,線程繼續運行,只有運行到cancelation-point的時候才會退出.
取消點:根據posix的標準,pthread_join,pthread_testcancel,pthread_cand_wait,
pthread_cond_timedwait,sem_wait,sigwait等函數以及read,write等會引起堵塞的調用都是
cancelation-point,而其他的pthread函數都不會引起cancelation動作,但pthread_cancel的手冊說明,
linuxthread的庫與C庫結合的并不是很好,因而目前的C函數庫都不是cancelation-point,
但cancel信號會使線程從堵塞的
系統調用中退出.并設置EINTR錯誤碼,因此可以在需要作為cancelation-point的系統調用前后調用
pthread_testcancel,從而達到POSIX的標準,例如
pthread_testcancel();
retcode=read(fd,buffer,length);
pthread_testcancel();
程序設計的考慮:
如果線程處于無限的循環中且循環沒有執行到取消點的必然路徑,則線程無法由于外部的其他線程的取消請求而終止,因此,在這樣的循環體中的必經路徑上加上pthread_testcancel()的調用.