在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()
函数进行。