在Linux中,`mutex_lock()`函数用于获取互斥锁(mutex lock)。它的用法是在代码块中调用该函数来获取互斥锁,以确保同一时间只有一个线程可以访问共享资源。
`mutex_lock()`函数的原型如下:
```c
int mutex_lock(pthread_mutex_t *mutex);
```
参数`mutex`是一个指向`pthread_mutex_t`类型的互斥锁变量的指针。
调用`mutex_lock()`函数会尝试获取互斥锁,如果互斥锁当前处于可用状态(没有其他线程持有该锁),则该线程成功获取锁并继续执行。如果互斥锁当前已被其他线程持有,则该线程将被阻塞,并等待互斥锁可用。
当线程成功获取互斥锁时,应该确保在不再需要访问共享资源时及时释放互斥锁,以允许其他线程获取锁并访问共享资源。释放互斥锁可以使用`mutex_unlock()`函数。
下面是一个简单的示例代码,演示了`mutex_lock()`函数的用法:
```c
#include
#include
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()`函数进行。