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