mutex_lock的實(shí)際案例分析

小樊
84
2024-09-04 04:47:42

mutex_lock 是一個(gè)用于同步多線程操作共享資源的函數(shù)

以下是一個(gè)簡(jiǎn)單的 C 語(yǔ)言示例,展示了如何使用 pthread_mutex_lockpthread_mutex_unlock 來(lái)保護(hù)共享資源(計(jì)數(shù)器):

#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;
}

在這個(gè)示例中,我們創(chuàng)建了 5 個(gè)線程,每個(gè)線程都會(huì)對(duì)共享資源(計(jì)數(shù)器)進(jìn)行 100,000 次遞增操作。通過(guò)使用互斥鎖(pthread_mutex_lockpthread_mutex_unlock),我們確保了在任何時(shí)候只有一個(gè)線程可以訪問(wèn)和修改計(jì)數(shù)器。最后,主線程等待所有子線程完成,并輸出計(jì)數(shù)器的值。由于我們正確地使用了互斥鎖,計(jì)數(shù)器的值應(yīng)該是 500,000。

0