中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

?linux中怎么創建多線程

發布時間:2022-03-23 16:40:59 來源:億速云 閱讀:191 作者:iii 欄目:web開發

這篇文章主要介紹了linux中怎么創建多線程的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇linux中怎么創建多線程文章都會有所收獲,下面我們一起來看看吧。

linux線程分為兩類:一是核心級支持線程,二是用戶級的線程。一般都為用戶級的線程。

一、多線程的幾個常見函數

要創建多線程必須加載pthread.h文件,庫文件pthread。線程的標識符pthread_t在頭文件/usr/include/bits/pthreadtypes.h中定義:typedef  unsigned  long  int  pthread_t

1.創建線程:

int pthread_create(pthread_t *restrict thread,
           const pthread_attr_t *restrict attr,
           void *(*start_routine)(void*), void *restrict arg);
參數:
      thread輸出線程id
     attr 線程屬性, 默認null
      start_routine線程執行函數
      arg線程執行參數 
note:函數成功返回0 否則返回錯誤碼

2.等待指定線程結束:

int pthread_join(pthread_t thread,void **value_ptr);
參數:
      thread一個有效的線程id
      value_ptr 接收線程返回值的指針
note:調用此函數的線程在指定的線程退出前將處于掛起狀態或出現錯誤而直接返回,如果value_ptr非null則value_ptr指向線程返回值的指針,函數成功后指定的線程使用的資源將被釋放。

3.退出線程:

int pthread_exit(void * value_ptr);
參數:
      value_ptr 線程返回值指針
note: ptrhead_exit()退出調用此函數的線程并釋放該線程占用的資源。

4.獲取當前線程id:

pthread_t pthread_self(void);
參數:     
note:返回當前函數的id

5.互斥

創建互斥:
int pthread_mutex_init(pthread_mutex_t *restrict mutex,
                     const pthread_mutexattr_t *restrict attr);
參數:
      mutex輸出互斥id
     attr 互斥屬性, 默認null
note:函數成功返回0 否則返回錯誤碼
鎖住互斥:
int pthread_mutex_lock(pthread_mutex_t *mutex);
參數:
      mutex互斥id
note:如果指定的互斥id已經被鎖住那么呼叫線程在互斥id完全解鎖前將一直處于掛起狀態,否則將鎖住互斥體。
int pthread_mutex_trylock(pthread_mutex_t *mutex);
參數:
      mutex互斥id
note:如果指定的互斥id已經被鎖住那么將直接返回一個錯誤,通過判斷此錯誤來進行不同的處理。pthread_mutex_trylock和pthread_mutex_lock相似,不同的是pthread_mutex_trylock只有在互斥被鎖住的情況下才阻塞。
解鎖互斥:
int pthread_mutex_unlock(pthread_mutex_t *mutex);
參數:
     mutex互斥id
note:如果指定的互斥id已經被鎖住那么對其解鎖
釋放互斥:
int pthread_mutex_destroy(pthread_mutex_t *mutex);
參數:
     mutex互斥id
note:釋放指定的mutex占用的資源。
函數pthread_mutex_init和pthread_mutex_destroy分別是互斥鎖的構造函數和析構函數。

 二、多線程同步

1.互斥體

互斥量(mutex)相當于一把鎖,可以保證以下三點:
◎原子性:如果一個線程鎖定一個互斥量,那么臨界區內的操作要么全部完成,要么一個也不執行。
◎惟一性:如果一個線程鎖定一個互斥量,那么在它解除鎖定之前,沒有其他線程可以鎖定這個互斥量。
◎非繁忙等待:如果一個線程已經鎖定一個互斥量,第二個線程又試圖去鎖定這個互斥量,則第二個線程將被掛起(不占用任何cpu資源),直到第一個線程解除對這個互斥量的鎖定為止。

2.條件變量

條件變量是一種可以使線程(不消耗cpu)等待某些事件發生的機制。某些線程可能守候著一個條件變量,直到某個其他的線程給這個條件變量發送一個信號,這時這些線程中的一個線程就會蘇醒,處理這個事件。但條件變量不提供鎖定,所以它必須與一個互斥量同時使用,提供訪問這個環境變量時必要的鎖定。
3.信號量
dijkstra提出了信號量的概念,信號量是一種特殊的變量,只可以取正整數值,對這個正整數只能采取兩種操作:p操作(代表等待,關操作)和v操作(代表信號,開操作)。
p/v操作定義如下(假設我們有一個信號量sem) :
p(sem):如果sem的值大于0,則sem減1;如果sem的值為0,則掛起該線程。
v(sem):如果有其它進程因等待sem而掛起,則讓它恢復執行;如果沒有線程等待sem而被掛起,則sem加上1。
信號集的創建與打開
int semget(key_t key,int nsems,int flag);
對信號量的操作
int semop(int semid,struct sembuf semoparray[],size_t nops);
對信號量的控制
int semctl(int semid,int semnum int cmd,union semun arg);
附:經典的生產者-消費者問題(producer-costomer)是一個著名的同步問題。

關于“linux中怎么創建多線程”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“linux中怎么創建多線程”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

教育| 洪雅县| 眉山市| 太仓市| 元谋县| 南江县| 阳春市| 淮滨县| 南丹县| 仁化县| 获嘉县| 双城市| 麻阳| 新郑市| 苗栗县| 咸宁市| 化德县| 中方县| 金沙县| 根河市| 桐柏县| 得荣县| 阜康市| 辽宁省| 友谊县| 芦溪县| 开阳县| 大英县| 小金县| 贞丰县| 湘阴县| 北海市| 合川市| 罗山县| 满城县| 大连市| 隆德县| 玛多县| 安宁市| 农安县| 长子县|