日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

线程基本编程——线程函数大全

發布時間:2024/4/19 编程问答 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 线程基本编程——线程函数大全 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
索引:
1.創建線程pthread_create
2.等待線程結束pthread_join
3.分離線程pthread_detach
4.創建線程鍵pthread_key_create
5.刪除線程鍵pthread_key_delete
6.設置線程數據pthread_setspecific
7.獲取線程數據pthread_getspecific
8.獲取線程標示符pthread_self
9.比較線程pthread_equal
10.一次執行pthread_once
11.出讓執行權sched_yield
12.修改優先級pthread_setschedparam
13.獲取優先級pthread_getschedparam
14.發送信號pthread_kill
15.設置線程掩碼pthread_sigmask
16.終止線程pthread_exit
17.退出線程pthread_cancel
18.允許/禁止退出線程pthread_setcancelstate
19.設置退出類型pthread_setcanceltype
20.創建退出點pthread_testcancel
21.壓入善后處理函數
22.彈出善后處理函數

--------------------------------------------------------------------------------

1.創建線程pthread_create
#include
int pthread_create(pthread_t *tid, const pthread_attr_t *tattr, void *(*start_routine)(void *), void *arg);
返回值:函數成功返回0。任何其他返回值都表示錯誤。

創建一個線程。

參數tattr中含有初始化線程所需要的屬性,start_routine是線程入口函數的地址,當start_routine返回時,相應的線程就結束了。

當函數成功時,線程標示符保存在參數tid指向的內存中。

如果不指定屬性對象,將其置為NULL,則創建一個缺省的線程,有如下屬性:

非綁定的;
未分離的;
由一個缺省大小的堆棧;
具有和父線程一樣的優先級。
注意:在創建子線程時,傳給子線程的輸入參數最好是由malloc()函數返回的指針或指向全局變量的指針,而不要是指向局部變量的指針。要保證子線程處理參數時,該區域仍然有效。

--------------------------------------------------------------------------------
2.等待線程結束pthread_join
#include
int pthread_join(pthread_t tid, void **status);
返回值:函數成功返回0。任何其他返回值都表示錯誤。

等待一個線程結束。

該函數阻塞調用它線程,直到參數tid指定的線程結束。

tid指定的線程必須在當前進程中,同時tid指定的線程必須是非分離的。

不能有多個線程等待同一個線程終止。如果出現這種情況,一個線程將成功返回,別的線程將返回錯誤ESRCH。

如果參數status不為NULL,則將線程的退出狀態放在status指向的內存中。

--------------------------------------------------------------------------------
3.分離線程pthread_detach
#include
int pthread_detach(pthread_t tid);
返回值:函數成功返回0。任何其他返回值都表示錯誤。

將非分離的線程設置為分離線程。即通知線程庫在指定的線程終止時回收線程占用的內存等資源。

在一個線程上使用多次pthread_detach的結果是不可預見的。

--------------------------------------------------------------------------------
4.創建線程鍵pthread_key_create
#include
int pthread_key_create(pthread_key_t *key, void (*destructor)(void*));
返回值:函數成功返回0。任何其他返回值都表示錯誤。

在進程中分配一個鍵值,這個鍵被用來表示一個線程數據項。這個鍵對進程中所有的線程都是可見的。剛創建線程數據鍵時,在所有線程中和這個鍵相關聯的值都是NULL。

函數成功返回后,分配的鍵放在key參數指向的內存中,必須保證key參數指向的內存區的有效性。

如果指定了解析函數destructor,那么當線程結束時并且將非空的值綁定在這個鍵上,系統將調用destructor函數,參數就是相關線程與這個鍵綁定的值。綁定在這個鍵上的內存塊可由destructor函數釋放。

--------------------------------------------------------------------------------
5.刪除線程鍵pthread_key_delete
#include
int pthread_key_delete(pthread_key_t key);
返回值:函數成功返回0。任何其他返回值都表示錯誤。

刪除線程數據鍵。這個鍵占用的內存將被釋放,該鍵再被引用將返回錯誤。

在調用該函數之前,程序必須釋放和本線程相關聯的資源,該函數不會引發線程數據鍵的解析函數。

--------------------------------------------------------------------------------
6.設置線程數據pthread_setspecific
#include
int pthread_setspecific(pthread_key_t key, const void *value);
返回值:函數成功返回0。任何其他返回值都表示錯誤。

設置和某個線程數據鍵綁定在一起的線程專用數據(一般是指針)。

函數不會釋放原來綁定在鍵上的內存,給一個鍵值綁定新的指針時,必須釋放原指針指向的內存,否則會發生內存泄漏。

--------------------------------------------------------------------------------
7.獲取線程數據pthread_getspecific
#include
void pthread_getspecific(pthread_key_t key, void **value);
無返回值。出錯時value指向NULL。

獲取綁定在線程數據鍵上的值,并在指定的位置存儲取來的值。

--------------------------------------------------------------------------------
8.獲取線程標示符pthread_self
#include
pthread_t pthread_self(void);

返回當前線程的標示符。

--------------------------------------------------------------------------------
9.比較線程pthread_equal
#include
int pthread_equal(pthread_t tid1, pthread_t tid2);
如果tid1和tid2相同,函數返回一個非0值,否則返回0。

如果tid1或tid2中任何一個是非法值,則返回將是不可預料的。

--------------------------------------------------------------------------------
10.一次執行pthread_once
#include
int pthread_once(pthread_once_t *once_control, void (*init_routine)(void));
返回值:函數成功返回0。任何其他返回值都表示錯誤。

函數用來調用初始化函數。如果已經有線程通過pthread_once調用過這個初始化函數一次,那么以后通過pthread_once函數再調用這個初始化函數將無效。

參數once_control決定了相應的初始化函數是否被調用過。它一般如下使用:
[static] pthread_once_t once_control = PTHREAD_ONCE_INIT。

--------------------------------------------------------------------------------
11.出讓執行權sched_yield
#include
int sched_yield(void);
返回值:函數成功返回0。-1表示錯誤。

把當前線程的執行權(即對處理器的控制權)出讓給另一個有相同或更高優先級的線程。

--------------------------------------------------------------------------------
12.修改優先級pthread_setschedparam
#include
int pthread_setschedparam(pthread_t tid, int policy, const struct sched_param *param);
返回值:函數成功返回0。任何其他返回值都表示錯誤。

修改線程的優先權。

--------------------------------------------------------------------------------
13.獲取優先級pthread_getschedparam
#include
int pthread_getschedparam(pthread_t tid, int policy, struct schedparam *param);
返回值:函數成功返回0。任何其他返回值都表示錯誤。

獲取線程的優先級。

--------------------------------------------------------------------------------
14.發送信號pthread_kill
#include
int pthread_kill(pthread_t tid, int sig);
返回值:函數成功返回0。任何其他返回值都表示錯誤。

向tid指定的線程發送一個信號,tid指定的線程必須和當前線程在同一個進程中。

當sig參數為0時,函數將進行錯誤檢查,不發送信號,這常常用來檢查tid的合法性。

--------------------------------------------------------------------------------
15.設置線程掩碼pthread_sigmask
#include
#include
int pthread_sigmask(int how, const sigset_t *new, sigset_t *old);
返回值:函數成功返回0。任何其他返回值都表示錯誤。

改變或檢驗當前線程的信號掩碼。

參數how表示對當前信號掩碼進行什么操作,有如下值:SIG_BLOCK、SIG_UNBLOCK、SIG_SETMASK。

當參數new為NULL時,不論how的值是什么,當前線程的信號掩碼都不會改變。

舊的信號掩碼保存在參數old指向的內存中,當old不為NULL時。

--------------------------------------------------------------------------------
16.終止線程pthread_exit
#include
void pthread_exit(void *status);

終止當前線程,所有綁定在線程數據鍵上的內存將被釋放。如果當前線程是非分離的,那么這個線程的標示符合退出代碼將被保留,直到其他線程用pthread_join來等待當前線程的終止。如果當前線程是分離的,status將被忽略,線程標示符將被立即回收。

若status不為NULL,線程的退出代碼被置為status參數指向的值。

--------------------------------------------------------------------------------
17.退出線程pthread_cancel
#include
int pthread_cancel(pthread_t thread);
返回值:函數成功返回0。任何其他返回值都表示錯誤。

退出一個線程。如何響應退出請求取決于目標線程的狀態。

--------------------------------------------------------------------------------
18.允許/禁止退出線程pthread_setcancelstate
#include
int pthread_setcancelstate(int state, int *oldstate);
返回值:函數成功返回0。任何其他返回值都表示錯誤。

參數state取值為PTHREAD_CANCEL_ENABLE或PTHREAD_CANCEL_DISABLE。

--------------------------------------------------------------------------------
19.設置退出類型pthread_setcanceltype
#include
int pthread_setcanceltype(int type, int *oldtype);
返回值:函數成功返回0。任何其他返回值都表示錯誤。

將線程退出類型設置為延遲類型或異步類型。參數type的取值為PTHREAD_CANCEL_DEFERRED或PTHREAD_CANCEL_ASYNCHRONOUS。

當一個線程被創建后,缺省值是延遲類型。在異步方式下,線程可以在執行的任何時候被退出。

--------------------------------------------------------------------------------
20.創建退出點pthread_testcancel
#include
void pthread_testcancel(void);
無返回值。

設置線程的退出點。

只有當線程的退出狀態是允許退出的,而且線程的退出類型是延遲時,調用該函數才有效。如果調用時線程的退出狀態是禁止的,則該調用不起作用。

小心使用該函數,只有在能夠安全的被退出的地方才能夠設置退出點。

--------------------------------------------------------------------------------
21.壓入善后處理函數
#include
void pthread_cleanup_push(void (*routine)(void *), void *args);

將一個善后處理函數壓入善后處理函數堆棧。

--------------------------------------------------------------------------------
22.彈出善后處理函數
#include
void pthread_cleanup_pop(int execute);

從善后處理函數堆棧中彈出一個善后處理函數。如果參數execute非0,則執行彈出的函數;如果參數為0,則不執行彈出函數。

如果一個線程顯式或隱式的調用pthread_exit()函數或線程接受了退出請求,線程庫實際上將會以非0參數調用pthread_cleanup_pop函數。
轉自:http://blog.chinaunix.net/space.php?uid=13760159&do=blog&cuid=1225657

總結

以上是生活随笔為你收集整理的线程基本编程——线程函数大全的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。