温馨提示×

linux中mutex_lock函数的用法是什么

小亿
159
2023-10-12 02:49:18
栏目: 编程语言

在Linux中,mutex_lock()函数用于获取互斥锁(mutex lock)。它的用法是在代码块中调用该函数来获取互斥锁,以确保同一时间只有一个线程可以访问共享资源。

mutex_lock()函数的原型如下:

int mutex_lock(pthread_mutex_t *mutex);

参数mutex是一个指向pthread_mutex_t类型的互斥锁变量的指针。

调用mutex_lock()函数会尝试获取互斥锁,如果互斥锁当前处于可用状态(没有其他线程持有该锁),则该线程成功获取锁并继续执行。如果互斥锁当前已被其他线程持有,则该线程将被阻塞,并等待互斥锁可用。

当线程成功获取互斥锁时,应该确保在不再需要访问共享资源时及时释放互斥锁,以允许其他线程获取锁并访问共享资源。释放互斥锁可以使用mutex_unlock()函数。

下面是一个简单的示例代码,演示了mutex_lock()函数的用法:

#include <stdio.h>
#include <pthread.h>
pthread_mutex_t mutex;  // 定义互斥锁
void* thread_function(void* arg) {
pthread_mutex_lock(&mutex);  // 获取互斥锁
// 访问共享资源
printf("Thread %d is accessing the shared resource.\n", *(int*)arg);
pthread_mutex_unlock(&mutex);  // 释放互斥锁
return NULL;
}
int main() {
pthread_t thread1, thread2;
pthread_mutex_init(&mutex, NULL);  // 初始化互斥锁
int id1 = 1;
pthread_create(&thread1, NULL, thread_function, &id1);  // 创建线程1
int id2 = 2;
pthread_create(&thread2, NULL, thread_function, &id2);  // 创建线程2
pthread_join(thread1, NULL);  // 等待线程1结束
pthread_join(thread2, NULL);  // 等待线程2结束
pthread_mutex_destroy(&mutex);  // 销毁互斥锁
return 0;
}

在这个例子中,我们创建了两个线程,它们都会执行thread_function()函数。每个线程在执行该函数时都会尝试获取互斥锁,然后访问共享资源并打印一条消息。当一个线程获取到互斥锁时,另一个线程将被阻塞,直到互斥锁被释放。

需要注意的是,互斥锁的初始化和销毁可以使用pthread_mutex_init()pthread_mutex_destroy()函数进行。

0