pthread_kill:
別被名字嚇到,pthread_kill可不是kill,而是向線程發(fā)送signal。還記得signal嗎,大部分signal的默認(rèn)動(dòng)作是終止進(jìn)程的運(yùn)行,所以,我們才要用signal()去抓信號(hào)并加上處理函數(shù)。
int pthread_kill(pthread_t thread, int sig);
向指定ID的線程發(fā)送sig信號(hào),如果線程代碼內(nèi)不做處理,則按照信號(hào)默認(rèn)的行為影響整個(gè)進(jìn)程,也就是說(shuō),如果你給一個(gè)線程發(fā)送了SIGQUIT,但線程卻沒(méi)有實(shí)現(xiàn)signal處理函數(shù),則整個(gè)進(jìn)程退出。
pthread_kill(threadid, SIGKILL)也一樣,殺死整個(gè)進(jìn)程。
如果要獲得正確的行為,就需要在線程內(nèi)實(shí)現(xiàn)signal(SIGKILL,sig_handler)了。
所以,如果int sig的參數(shù)不是0,那一定要清楚到底要干什么,而且一定要實(shí)現(xiàn)線程的信號(hào)處理函數(shù),否則,就會(huì)影響整個(gè)進(jìn)程。
OK,如果int sig是0呢,這是一個(gè)保留信號(hào),一個(gè)作用是用來(lái)判斷線程是不是還活著。
我們來(lái)看一下pthread_kill的返回值:
成功:0
線程不存在:ESRCH
信號(hào)不合法:EINVAL
所以,pthread_kill(threadid,0)就很有用啦。
int kill_rc = pthread_kill(thread_id,0);
if(kill_rc == ESRCH)
printf("the specified thread did not exists or already quit\n");
else if(kill_rc == EINVAL)
printf("signal is invalid\n");
else
printf("the specified thread is alive\n");
上述的代碼就可以判斷線程是不是還活著了。