初始化互斥锁
int pthread_mutex_init(pthread_mutex_t *mutex,const pthread_mutexattr_t *attr);
参数attr指定了新建互斥锁的属性。如果参数attr为NULL,则使用默认的互斥锁属性。
锁定互斥锁
int pthread_mutex_lock(pthread_mutex_t *mutex);
当 pthread_mutex_lock() 返回时,该互斥锁已被锁定。调用线程是该互斥锁的属主。如果该互斥锁已被另一个线程锁定和拥有,则调用线程将阻塞,直到该互斥锁变为可用为止。
解除互斥锁
int pthread_mutex_unlock(pthread_mutex_t *mutex);
释放 mutex 引用的互斥锁对象。如果调用 pthread_mutex_unlock() 时有多个线程被 mutex 对象阻塞,则互斥锁变为可用时调度策略可确定获取该互斥锁的线程。
使用非阻塞方式锁定
int pthread_mutex_trylock(pthread_mutex_t *mutex);
如果 mutex 所引用的互斥对象当前被任何线程(包括当前线程)锁定,则将立即返回该调用。
销毁互斥锁
int pthread_mutex_destroy(pthread_mutex_t *mp);
一个例子:
#include <pthread.h>
#include <stdio.h>pthread_mutex_t mutex ;
void *print_msg(void *arg){int i=0;pthread_mutex_lock(&mutex);for(i=0;i<15;i++){printf("output : %d\n",i);usleep(100);}pthread_mutex_unlock(&mutex);
}
int main(int argc,char** argv){pthread_t id1;pthread_t id2;pthread_mutex_init(&mutex,NULL);pthread_create(&id1,NULL,print_msg,NULL);pthread_create(&id2,NULL,print_msg,NULL);pthread_join(id1,NULL);pthread_join(id2,NULL);pthread_mutex_destroy(&mutex);return 1;
}
结果是一个线程一个线程地执行。