linux中线程在执行过程中都有可能因为cpu的资源问题而导致暂时失去执行的权利而导致某些问题。
- 在某些线程例如使用了alarm()定时后,却应为暂时失去cpu资源而导致下一步动作没能执行pause(),回复执行的权利的时间>定时的时间,导致进程一直挂起。
- 如果加上锁将alarm()与pause()绑定在一起,就能避免这种问题的出现
互斥锁是Linux锁机制中的一种锁,该锁的特点:
- 同一时刻只能有一个线程持有互斥锁
- 互斥锁只对执行了加载互斥锁的线程具有作用
- 互斥锁是一把建议锁,没有强制的限制
1 /*
2 头文件:#include<pthread.h>
3 返回值:成功返回0;失败返回错误号
4
5 初始化锁:(创建互斥锁)
6 int pthread_mutex_init(pthread_mutex_t *restrict mutex,const pthread_mutexattr_t *restrict attr);
7
8 销毁锁:(释放锁占用的资源)
9 int pthread_mutex_destroy(pthread_mutex_t *mutex);
10
11 加锁:(若该锁被其他线程持有,则阻塞等待)
12 int pthread_mutex_lock(pthread_mutex_t *mutex);
13
14 尝试加锁:(即使该锁被其他线程持有,也不阻塞等待,继续执行下一步动作)
15 int pthread_mutex_trylock(pthread_mutex_t *mutex);
16
17 解锁:(释放该互斥锁的持有,其他线程可以争夺该锁)
18 int pthread_mutex_unlock(pthread_mutex_t *mutex);
19
20 返回值:成功返回0;失败返回错误号
21
22 pthread_mutex_t:定义锁
23 pthread_mutex_t mutex:变量mutex只有两种取值:1或0
24 加锁成功mutex被置为0 解锁成功mutex被置为1
25 restrict:限制mutex只能由本变量更改值,不能被其他原因改变值
26
27 */