1. 程式人生 > >pthread_kill-----向執行緒傳送訊號

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)就很有用啦。

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");

上述的程式碼就可以判斷執行緒是不是還活著了。

/*linux中使用pthread_kill函式測試執行緒是否存活的例子 */
/******************************* pthread_kill.c *******************************/
#include <stdio.h>
#include <stdlib.h>
#include <pthread.h>
#include <errno.h>
void *func1()/*1秒鐘之後退出*/
{    
    sleep(1);  
 
    printf("執行緒1run \n");  
    printf("執行緒1(ID:0x%x)退出。\n",(unsigned int)pthread_self());  
    pthread_exit((void *)0);
}
void *func2()/*5秒鐘之後退出*/
{
    sleep(5); 
 
    printf("執行緒2run \n");  
    printf("執行緒2(ID:0x%x)退出。\n",(unsigned int)pthread_self());  
    pthread_exit((void *)0);
}
void test_pthread(pthread_t tid)
 /*通過pthread_kill的返回值:來判斷
 * 成功(0)
 *  執行緒不存在(ESRCH)
 *   訊號不合法(EINVAL)
 *   */
{   
     int pthread_kill_err;   
     pthread_kill_err = pthread_kill(tid,0);  
    if(pthread_kill_err == ESRCH)     
    printf("ID為0x%x的執行緒不存在或者已經退出。\n",(unsigned int)tid);
    else 
   if(pthread_kill_err == EINVAL)        printf("傳送訊號非法。\n");   
       else    
        printf("ID為0x%x的執行緒目前仍然存活。\n",(unsigned int)tid);
}
int main()
{    int ret;   
 pthread_t tid1,tid2;   
     pthread_create(&tid1,NULL,func1,NULL); 
   pthread_create(&tid2,NULL,func2,NULL);     
   sleep(3);/*建立兩個程序3秒鐘之後,分別測試一下它們是否還活著*/   
     test_pthread(tid1);/*測試ID為tid1的執行緒是否存在*/  
  test_pthread(tid2);/*測試ID為tid2的執行緒是否存在*/   
pthread_join(tid2,NULL);//wati thread2 exit 
 exit(0);
}