Posix互斥锁被声明为具有
pthread_mutex_t
数据类型的变量。
如果互斥锁变量是 静态分配 的,那么可以使用 PTHREAD_MUTEX_INITIALIZER 来进行初始化。
如果互斥锁变量是 动态分配 的,那么就应该用 pthread_mutex_init 来进行初始化。
初始化::
#include <pthread.h>
int pthread_mutex_init(pthread_mutex_t *,pthread_mutexattr_t *); //默认第二个参数是NULL
或
PTHREAD_MUTEX_INITIALIZER
销毁::
#include <pthread.h>
int pthread_mutex_destroy(pthread_mutex_t *);
互斥锁上锁::
#include <pthread.h>
int pthread_mutex_lock(pthread_mutex_t *);
int pthread_mutex_trylock(pthread_mutex_t *);
互斥锁解锁::
#include <pthread.h>
int prhead_mutex_unlock(pthread_mutex_t *);
阻塞加锁pthread_mutex_lock::
如果尝试给一个已由另外一个线程锁住的互斥锁上锁,那么pthread_mutex_lock将阻塞,直到该互斥锁解锁为止。
非阻塞加锁pthread_mutex_trylock::
如果尝试给一个已由另外一个线程锁住的互斥锁上锁,那么pthread_mutex_trylock将立即返回,并返回错误码在errno中,为EBUSY。
(当有多个线程互斥加锁阻塞在同一个地方时,当锁被释放时,优先释放优先级最高的线程)
如果互斥锁变量是 静态分配 的,那么可以使用 PTHREAD_MUTEX_INITIALIZER 来进行初始化。
如果互斥锁变量是 动态分配 的,那么就应该用 pthread_mutex_init 来进行初始化。
初始化::
#include <pthread.h>
int pthread_mutex_init(pthread_mutex_t *,pthread_mutexattr_t *); //默认第二个参数是NULL
或
PTHREAD_MUTEX_INITIALIZER
销毁::
#include <pthread.h>
int pthread_mutex_destroy(pthread_mutex_t *);
互斥锁上锁::
#include <pthread.h>
int pthread_mutex_lock(pthread_mutex_t *);
int pthread_mutex_trylock(pthread_mutex_t *);
互斥锁解锁::
#include <pthread.h>
int prhead_mutex_unlock(pthread_mutex_t *);
阻塞加锁pthread_mutex_lock::
如果尝试给一个已由另外一个线程锁住的互斥锁上锁,那么pthread_mutex_lock将阻塞,直到该互斥锁解锁为止。
非阻塞加锁pthread_mutex_trylock::
如果尝试给一个已由另外一个线程锁住的互斥锁上锁,那么pthread_mutex_trylock将立即返回,并返回错误码在errno中,为EBUSY。
(当有多个线程互斥加锁阻塞在同一个地方时,当锁被释放时,优先释放优先级最高的线程)
尽管我们说互斥锁保护的是临界区,实际上保护的是临界区中被操作的数据(da
由于pthread_mutex_t几乎不占资源,所以一般destroy函数很少去调用,一般用于判断互斥量的状态。
下面是关于互斥量上锁和解锁的例子;
#include <iostream>
#include <pthread.h>
using namespace std;
pthread_mutex_t mutex; //~ 创建互斥锁mutex
int share = 0; //~ 共享数据
//~ 线程入口
void * thread_function(void *arg)
{
const int N = 1000000;
for(int i = 0; i < N; ++i)
{
//~ 访问共享数据
pthread_mutex_lock(&mutex);
share++;
pthread_mutex_unlock(&mutex);
}
}
int
main()
{
pthread_mutex_init(&mutex, NULL); //~ 初始化互斥锁mutex
pthread_t thread_id;
void *exit_status;
pthread_create(&thread_id, NULL, thread_function, NULL); //~ 创建新线程
for(int i = 0; i < 10; ++i)
{
usleep(10000); //~ 延时10ms
//~ 访问共享数据
pthread_mutex_lock(&mutex);
cout<<share<<endl;
pthread_mutex_unlock(&mutex);
}
pthread_join(thread_id, &exit_status); //~ 等待线程结束
pthread_mutex_destroy(&mutex); //~ 销毁互斥锁
return 0;
}