這篇文章主要介紹了linux中怎么創(chuàng)建多線程的相關(guān)知識(shí),內(nèi)容詳細(xì)易懂,操作簡(jiǎn)單快捷,具有一定借鑒價(jià)值,相信大家閱讀完這篇linux中怎么創(chuàng)建多線程文章都會(huì)有所收獲,下面我們一起來(lái)看看吧。
10年積累的做網(wǎng)站、成都網(wǎng)站設(shè)計(jì)經(jīng)驗(yàn),可以快速應(yīng)對(duì)客戶對(duì)網(wǎng)站的新想法和需求。提供各種問(wèn)題對(duì)應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識(shí)你,你也不認(rèn)識(shí)我。但先網(wǎng)站設(shè)計(jì)后付款的網(wǎng)站建設(shè)流程,更有寧武免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
linux線程分為兩類:一是核心級(jí)支持線程,二是用戶級(jí)的線程。一般都為用戶級(jí)的線程。
一、多線程的幾個(gè)常見(jiàn)函數(shù)
要?jiǎng)?chuàng)建多線程必須加載pthread.h文件,庫(kù)文件pthread。線程的標(biāo)識(shí)符pthread_t在頭文件/usr/include/bits/pthreadtypes.h中定義:typedef unsigned long int pthread_t
1.創(chuàng)建線程:
int pthread_create(pthread_t *restrict thread,
const pthread_attr_t *restrict attr,
void *(*start_routine)(void*), void *restrict arg);
參數(shù):
thread輸出線程id
attr 線程屬性, 默認(rèn)null
start_routine線程執(zhí)行函數(shù)
arg線程執(zhí)行參數(shù)
note:函數(shù)成功返回0 否則返回錯(cuò)誤碼
2.等待指定線程結(jié)束:
int pthread_join(pthread_t thread,void **value_ptr);
參數(shù):
thread一個(gè)有效的線程id
value_ptr 接收線程返回值的指針
note:調(diào)用此函數(shù)的線程在指定的線程退出前將處于掛起狀態(tài)或出現(xiàn)錯(cuò)誤而直接返回,如果value_ptr非null則value_ptr指向線程返回值的指針,函數(shù)成功后指定的線程使用的資源將被釋放。
3.退出線程:
int pthread_exit(void * value_ptr);
參數(shù):
value_ptr 線程返回值指針
note: ptrhead_exit()退出調(diào)用此函數(shù)的線程并釋放該線程占用的資源。
4.獲取當(dāng)前線程id:
pthread_t pthread_self(void);
參數(shù):
note:返回當(dāng)前函數(shù)的id
5.互斥
創(chuàng)建互斥:
int pthread_mutex_init(pthread_mutex_t *restrict mutex,
const pthread_mutexattr_t *restrict attr);
參數(shù):
mutex輸出互斥id
attr 互斥屬性, 默認(rèn)null
note:函數(shù)成功返回0 否則返回錯(cuò)誤碼
鎖住互斥:
int pthread_mutex_lock(pthread_mutex_t *mutex);
參數(shù):
mutex互斥id
note:如果指定的互斥id已經(jīng)被鎖住那么呼叫線程在互斥id完全解鎖前將一直處于掛起狀態(tài),否則將鎖住互斥體。
int pthread_mutex_trylock(pthread_mutex_t *mutex);
參數(shù):
mutex互斥id
note:如果指定的互斥id已經(jīng)被鎖住那么將直接返回一個(gè)錯(cuò)誤,通過(guò)判斷此錯(cuò)誤來(lái)進(jìn)行不同的處理。pthread_mutex_trylock和pthread_mutex_lock相似,不同的是pthread_mutex_trylock只有在互斥被鎖住的情況下才阻塞。
解鎖互斥:
int pthread_mutex_unlock(pthread_mutex_t *mutex);
參數(shù):
mutex互斥id
note:如果指定的互斥id已經(jīng)被鎖住那么對(duì)其解鎖
釋放互斥:
int pthread_mutex_destroy(pthread_mutex_t *mutex);
參數(shù):
mutex互斥id
note:釋放指定的mutex占用的資源。
函數(shù)pthread_mutex_init和pthread_mutex_destroy分別是互斥鎖的構(gòu)造函數(shù)和析構(gòu)函數(shù)。
二、多線程同步
1.互斥體
互斥量(mutex)相當(dāng)于一把鎖,可以保證以下三點(diǎn):
◎原子性:如果一個(gè)線程鎖定一個(gè)互斥量,那么臨界區(qū)內(nèi)的操作要么全部完成,要么一個(gè)也不執(zhí)行。
◎惟一性:如果一個(gè)線程鎖定一個(gè)互斥量,那么在它解除鎖定之前,沒(méi)有其他線程可以鎖定這個(gè)互斥量。
◎非繁忙等待:如果一個(gè)線程已經(jīng)鎖定一個(gè)互斥量,第二個(gè)線程又試圖去鎖定這個(gè)互斥量,則第二個(gè)線程將被掛起(不占用任何cpu資源),直到第一個(gè)線程解除對(duì)這個(gè)互斥量的鎖定為止。
2.條件變量
條件變量是一種可以使線程(不消耗cpu)等待某些事件發(fā)生的機(jī)制。某些線程可能守候著一個(gè)條件變量,直到某個(gè)其他的線程給這個(gè)條件變量發(fā)送一個(gè)信號(hào),這時(shí)這些線程中的一個(gè)線程就會(huì)蘇醒,處理這個(gè)事件。但條件變量不提供鎖定,所以它必須與一個(gè)互斥量同時(shí)使用,提供訪問(wèn)這個(gè)環(huán)境變量時(shí)必要的鎖定。
3.信號(hào)量
dijkstra提出了信號(hào)量的概念,信號(hào)量是一種特殊的變量,只可以取正整數(shù)值,對(duì)這個(gè)正整數(shù)只能采取兩種操作:p操作(代表等待,關(guān)操作)和v操作(代表信號(hào),開(kāi)操作)。
p/v操作定義如下(假設(shè)我們有一個(gè)信號(hào)量sem) :
p(sem):如果sem的值大于0,則sem減1;如果sem的值為0,則掛起該線程。
v(sem):如果有其它進(jìn)程因等待sem而掛起,則讓它恢復(fù)執(zhí)行;如果沒(méi)有線程等待sem而被掛起,則sem加上1。
信號(hào)集的創(chuàng)建與打開(kāi)
int semget(key_t key,int nsems,int flag);
對(duì)信號(hào)量的操作
int semop(int semid,struct sembuf semoparray[],size_t nops);
對(duì)信號(hào)量的控制
int semctl(int semid,int semnum int cmd,union semun arg);
附:經(jīng)典的生產(chǎn)者-消費(fèi)者問(wèn)題(producer-costomer)是一個(gè)著名的同步問(wèn)題。
關(guān)于“l(fā)inux中怎么創(chuàng)建多線程”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對(duì)“l(fā)inux中怎么創(chuàng)建多線程”知識(shí)都有一定的了解,大家如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
名稱欄目:?linux中怎么創(chuàng)建多線程
標(biāo)題URL:http://aaarwkj.com/article28/goodjp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供用戶體驗(yàn)、外貿(mào)建站、網(wǎng)站設(shè)計(jì)、企業(yè)網(wǎng)站制作、網(wǎng)站策劃、全網(wǎng)營(yíng)銷推廣
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)