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