mutex_lock
是一個用于同步多線程操作共享資源的函數
以下是一個簡單的 C 語言示例,展示了如何使用 pthread_mutex_lock
和 pthread_mutex_unlock
來保護共享資源(計數器):
#include<stdio.h>
#include <stdlib.h>
#include <pthread.h>
#define NUM_THREADS 5
int counter = 0;
pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;
void *increment(void *arg) {
int i;
for (i = 0; i < 100000; i++) {
pthread_mutex_lock(&mutex); // 加鎖
counter++;
pthread_mutex_unlock(&mutex); // 解鎖
}
return NULL;
}
int main() {
pthread_t threads[NUM_THREADS];
int i;
for (i = 0; i < NUM_THREADS; i++) {
pthread_create(&threads[i], NULL, increment, NULL);
}
for (i = 0; i < NUM_THREADS; i++) {
pthread_join(threads[i], NULL);
}
printf("Counter: %d\n", counter);
return 0;
}
在這個示例中,我們創建了 5 個線程,每個線程都會對共享資源(計數器)進行 100,000 次遞增操作。通過使用互斥鎖(pthread_mutex_lock
和 pthread_mutex_unlock
),我們確保了在任何時候只有一個線程可以訪問和修改計數器。最后,主線程等待所有子線程完成,并輸出計數器的值。由于我們正確地使用了互斥鎖,計數器的值應該是 500,000。