【C++ 語言】pthread_mutex_t 互斥鎖
文章目錄
線程同步機制
互斥鎖
互斥鎖使用示例
線程同步機制引入 : 多個線程讀取同一個資源時 , 可能會造成沖突 , 因此需要引入線程同步機制 , 讓多個線程按照一定規則對共享的資源進行操作 ;
互斥鎖使用流程 : ① 聲明互斥鎖 , ② 初始化互斥鎖 , ③ 加鎖 , ④ 解鎖 , ⑤ 銷毀互斥鎖 ;
① 聲明互斥鎖 ;
pthread_mutex_t mutex_t;
1
② 初始化互斥鎖 :
//初始化互斥鎖 pthread_mutex_init(&mutex_t, 0);
1
2
③ 加鎖 :
//先用互斥鎖上鎖 pthread_mutex_lock(&mutex_t);
1
2
④ 解鎖 :
//操作完畢后, 解鎖 pthread_mutex_unlock(&mutex_t);
1
2
⑤ 銷毀互斥鎖 :
//銷毀互斥鎖 pthread_mutex_destroy(&mutex_t);
1
2
代碼示例 :
#include "005_Thread.h" #include
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
執行結果 :
獲取 queue_thread 隊列第一個數據 : 0 獲取 queue_thread 隊列第一個數據 : 1 獲取 queue_thread 隊列第一個數據 : 2 獲取 queue_thread 隊列第一個數據 : 3 獲取 queue_thread 隊列第一個數據 : 4 獲取 queue_thread 隊列為空 獲取 queue_thread 隊列為空
1
2
3
4
5
6
7
C++ 任務調度
版權聲明:本文內容由網絡用戶投稿,版權歸原作者所有,本站不擁有其著作權,亦不承擔相應法律責任。如果您發現本站中有涉嫌抄襲或描述失實的內容,請聯系我們jiasou666@gmail.com 處理,核實后本網站將在24小時內刪除侵權內容。
版權聲明:本文內容由網絡用戶投稿,版權歸原作者所有,本站不擁有其著作權,亦不承擔相應法律責任。如果您發現本站中有涉嫌抄襲或描述失實的內容,請聯系我們jiasou666@gmail.com 處理,核實后本網站將在24小時內刪除侵權內容。