在mysql中,可用“pThread_kill()”函數判斷線程是否存在,該函數可以向指定ID的線程發送sig信號,用來判斷線程是不是還活著,語法為“int pthread_kill(pthread_t thread, int sig)”。
本教程操作環境:linux7.3系統、Dell G3電腦。
linux怎么判斷線程是否存在
pthread_kill:
別被名字嚇到,pthread_kill可不是kill,而是向線程發送signal。還記得signal嗎,大部分signal的默認動作是終止進程的運行,所以,我們才要用signal()去抓信號并加上處理函數。
int?pthread_kill(pthread_t?thread,?int?sig);
向指定ID的線程發送sig信號,如果線程代碼內不做處理,則按照信號默認的行為影響整個進程,也就是說,如果你給一個線程發送了SIGQUIT,但線程卻沒有實現signal處理函數,則整個進程退出。
pthread_kill(threadid, SIGKILL)也一樣,殺死整個進程。
如果要獲得正確的行為,就需要在線程內實現signal(SIGKILL,sig_handler)了。
所以,如果int sig的參數不是0,那一定要清楚到底要干什么,而且一定要實現線程的信號處理函數,否則,就會影響整個進程。
OK,如果int sig是0呢,這是一個保留信號,一個作用是用來判斷線程是不是還活著。
我們來看一下pthread_kill的返回值:
-
成功:0
-
線程不存在:ESRCH
-
信號不合法:EINVAL
所以,pthread_kill(threadid,0)就很有用啦。
上述的代碼就可以判斷線程是不是還活著了。
相關推薦:《Linux視頻教程》
? 版權聲明
文章版權歸作者所有,未經允許請勿轉載。
THE END
喜歡就支持一下吧
相關推薦