Mutex_lock

mutex_lock的实际案例分析

小樊
82
2024-09-04 04:47:42
栏目: 编程语言

mutex_lock 是一个用于同步多线程操作共享资源的函数

以下是一个简单的 C 语言示例,展示了如何使用 pthread_mutex_lockpthread_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_lockpthread_mutex_unlock),我们确保了在任何时候只有一个线程可以访问和修改计数器。最后,主线程等待所有子线程完成,并输出计数器的值。由于我们正确地使用了互斥锁,计数器的值应该是 500,000。

0
看了该问题的人还看了