要向全局变量添加互斥锁,可以使用Linux系统提供的pthread库中的互斥锁。以下是一个示例代码:
#include <stdio.h>
#include <stdlib.h>
#include <pthread.h>
int global_var = 0;
pthread_mutex_t mutex;
void* thread_function(void* arg) {
// 加锁
pthread_mutex_lock(&mutex);
// 修改全局变量
global_var++;
// 解锁
pthread_mutex_unlock(&mutex);
return NULL;
}
int main() {
pthread_t thread1, thread2;
// 初始化互斥锁
pthread_mutex_init(&mutex, NULL);
// 创建线程
pthread_create(&thread1, NULL, thread_function, NULL);
pthread_create(&thread2, NULL, thread_function, NULL);
// 等待线程结束
pthread_join(thread1, NULL);
pthread_join(thread2, NULL);
// 打印最终结果
printf("global_var = %d\n", global_var);
// 销毁互斥锁
pthread_mutex_destroy(&mutex);
return 0;
}
在上述代码中,我们使用了pthread库中的pthread_mutex_t数据类型来定义一个互斥锁变量mutex。在各个线程中修改全局变量global_var之前,先使用pthread_mutex_lock函数来加锁,然后修改完全局变量后使用pthread_mutex_unlock函数来解锁。这样可以保证在同一时间只有一个线程可以修改全局变量,避免了竞争条件的发生。最后,通过pthread_mutex_init和pthread_mutex_destroy来初始化和销毁互斥锁。
需要注意的是,不要忘记在每个线程中使用pthread_mutex_lock和pthread_mutex_unlock成对出现,否则可能导致死锁或其他问题。