线程同步,指一个线程发出同一功能调用时,在没有得到结果之前,该调用不返回。同时其他线程为保证数据一致性,不能调用该功能
同步方法
锁的使用:建议锁,对公共数据进行保护,所有线程应该在访问公共数据前先拿锁再访问,但锁本身不具备强制性
互斥量
pthread_mutex_t mutex
phtread_mutex_init(&mutex,NULL);
phtread_mutex_destroy(&mutex,NULL);
pthread_mutex_lock(&mutex)
pthread_mutex_trylock(&mutex) 尝试加锁,,失败立即返回错误BUSY,不阻塞
pthread_mutex_unlock
restrict 关键字:用来限定指针变量,被该关键字限定的指针变量所指向的内存操作,必须由本指针完成
注意事项: 尽量保证锁的粒度,越小越好
读写锁
pthread_rwlock_init
pthread_rwlock_destroy
pthread_rwlock_rdlock
pthread_rwlock_wrlock
pthread_rwlock_tryrdlock
pthread_rwlock_trywrlock
pthread_rwlock_unlock
成功返回0 ,失败直接返回错误号
pthread_rwlock_t 读写锁
条件变量
本身不是锁,通常结合锁来使用
pthread_cont_t //条件变量结构定义
pthread_cond_init
pthread_cond_destroy
pthread_cond_wait // 等待条件满足
pthread_cond_timedwait //限时等待条件满足
pthread_cond_signal // 唤醒阻塞在条件变量的单个线程
pthread_cond_broadcast // 唤醒阻塞在条件变量的所有线程
pthread_cond_wait (condition,mutex)
函数作用:
- 阻塞等待条件满足
- 释放已掌握的互斥锁,1。2 两步为原子操作
- 当被唤醒,函数返回时,解除阻塞,并重新申请互斥锁,相当于phtread_mutex_lock(mutex)
pthread_cond_timedwait (condition,mutex,abstime)
信号量
可以应用于线程和进程间同步
相当于初始化值为N的互斥量,N表示可以同时访问的线程数量
sem_t sem
int sem_init(sem_t *sem,int pshared,unsigned int value)
pshared: 0 : 用于线程间同步
1:用于进程间同步
value: N值
sem_destroy
sem_wait 等价 pthread_mutex_lock, 将信号量–,当为0时,就会阻塞
sem_trywait
sem_timedwait
sem_post 等价 pthread_mutex_unlock, 将信号量++