线程 锁(二)
线程 锁(二)
线程
读写锁
- 当读写锁是加写锁时, 其他试图加写锁的线程都会被阻塞, 加读锁的也会被阻塞到写锁释放为止.
- 读写锁是加写锁时, 其他试图加写锁的线程可以共享数据.
读写锁的函数
#include <pthread.h>
// 分配一个读写锁
int pthread_rwlock_init(pthread_rwlock_t *restrict rwlock, const pthread_rwlockattr_t *restrict *attr)
// 释放读写锁
int pthread_rwlock_destroy(pthread_rwlock_t rwlock)
// 成功, 返回 0; 失败. 返回错误编码
// 静态分配:
pthread_rwlock_t t = PTHREAD_RWLOCK_INITALLZER;
读写锁在使用之前一定要初始化, 在释放他们底层的内存之前必须销毁
同样, 如果在调用pthread_rwlock_destroy之前就释放读写锁的空间, 那么分配的空间就会丢失
锁
#include <pthread.h>
int pthread_rwlock_rlock(pthread_rwlock_t *rwlock) // 读锁
int pthread_rwlock_wlock(pthread_rwlock_t *rwlock) // 写锁
int pthread_rwlock_unlock(pthread_rwlock_t *rwlock) // 解锁
// 成功, 返回 0; 失败, 返回错误编码
条件变量
1. 条件变量给多个线程提供一个汇合的机会.
2. 条件变量与互斥量一起使用时, 允许线程无竞争的方式等待特定的条件变量执行.
3. 条件本身由互斥量保护的. 线程在改变条件之前应该首先锁住互斥量
条件变量创建
#include <pthread.h>
int pthread_cond_init(pthread_cond_t *restrict cond, const pthread_condattr_t *restrict attr)
int pthread_cond_destroy(pthread_cond_t *restrict cond)
// 成功, 返回 0; 失败, 返回错误编码
变量锁
#include <pthread.h>
int pthread_cond_wait(pthread_cond_t *restrict cond, pthread_mutex_t *restrict mutex)
// tsptr : 等待时间
int pthread_cond_timedwait(pthread_cond_t *restrict cond, pthread_mutex_t *restrict mutex, const struct timespec *restrict tsptr)
// 成功, 返回 0; 失败, 返回错误编码
唤醒等待条件的线程
这是再给线程或条件发信号
#include <pthread.h>
// 至少能唤醒一个等待条件的线程
int pthread_cond_signal(pthread_cond_t *cond)
// 唤醒所有等待条件的线程
int pthread_cond_broadcast(pthread_cond_t *cond)
// 成功, 返回 0; 失败, 返回错误编码
自己照着一篇博主写的代码, 发现写的并不是很好
这里是博主的地址, 写的很详尽的, 我也就不再多写了, 毕竟写的也不容易, 太花时间了, 还要准备上课, 不过写的希望对大家有帮助
地址 : https://www.cnblogs.com/yuuyuu/p/5140875.html