进程和和线程
互斥锁mutex
在操作系统中,有临界区的概念。临界区内放的一般是被1个以上的进程或线程(以下只说进程)共用的数据。
临界区内的数据一次只能同时被一个进程使用,当一个进程使用临界区内的数据时,其他需要使用临界区数据的进程进入等待状态。
操作系统需要合理的分配临界区以达到多进程的同步和互斥关系,如果协调不好,就容易使系统处于不安全状态,甚至出现死锁现象。
摘自百科
那么于是需要mutex来阻塞其他线程,于是
pthread_mutex_lock()
...
//临界区(将其转化为“原子操作”)
...
//解锁
pthread_mutex_unlock()
mutex有静态和动态2种
pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER
//静态
//动态
int pthread_mutex_init(pthread_mutex_t *restrict mutex, \
const pthread_mutexattr _t *restrict attr);
//mutex:要初始化的互斥量 ; attr:属性,先设置为NULL
int pthread_mutex_destroy(pthread_mutex_t *mutex)//销毁动态初始化的mutex
下面举例说明
int some=0;
pthread_mutex_t lock;
void *route(void* arg