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。
(当有多个线程互斥加锁阻塞在同一个地方时,当锁被释放时,优先释放优先级最高的线程)
尽管我们说互斥锁保护的是临界区,实际上保护的是临界区中被操作的数据(da ta)。
如果互斥锁变量是 静态分配的,那么可以使用 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