std::shared_mutex 与 std::shared_lock 是读者或作者的首选
std::shared_mutex with std::shared_lock is reader or writer preferring?
在实现读写器锁时,我们可以利用std::shared_mutex
与std::shared_lock
和std::lock_guard
或std::unique_lock
。
问题>这个新的专题作者或读者更喜欢吗?
根据安德鲁的评论进行更新
参考:
// Multiple threads/readers can read the counter's value at the same time.
unsigned int get() const {
std::shared_lock<std::shared_mutex> lock(mutex_);
return value_;
}
// Only one thread/writer can increment/write the counter's value.
void increment() {
std::unique_lock<std::shared_mutex> lock(mutex_);
value_++;
}
正如你从上面的例子中看到的,我无法控制读取器/写入器的优先级。
在实践中:
- libc++总是使用Howard提到的互斥+条件变量技术,这并不奇怪。
- libstdc++ 在可用的情况下使用
pthread_rwlock_t
,如果不是,则回退到 Howard 提到的算法。因此,如果pthread_rwlock_t
可用,则使用的算法取决于 pthreads 实现。我相信 glibc 默认更喜欢读者。 -
MSVC使用Windows
SRWLOCK
,其文档说无法保证请求的线程的顺序 所有权将被授予所有权;SRW 锁既不公平也不公平 先进先出。
它都不是(如果实现得当(。 相反,读者和作家是通过公平的技术选择下一个。 这就是为什么这个特征既不能在 API 中设置,也不能指定。
这个答案详细介绍了如何实现这一点。
相关文章:
- 使用std::multimap迭代器创建std::list
- C++中std::resize(n)和std::shrink_to_fit之间的区别
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- C++17复制构造函数,在std::unordereded_map上进行深度复制
- 如何导出包含具有"std::unique_ptr"值的"std::map"属性的
- 从持续时间构造std::chrono::system_clock::time_point
- std::具有相同基类的类的变体
- std::向量与传递值的动态数组
- 使用std::vector的OpenCL矩阵乘法
- std::map<struct,struct>::find 找不到匹配项,但是如果我循环通过 begin() 到 end(),我在那里看到匹配项
- std::condition_variable::wait()如何评估给定的谓词
- 如何获取std::result_of函数的返回类型
- std::原子加载和存储都需要吗
- 将对象移动到std::shared_ptr
- POCO::PostgreSQL:如何将std::vector支持添加到`Binder::bind`
- 引用 std::shared:ptr 以避免引用计数
- boost::shared_ptr和std::shared-ptr的同居
- 我可以用std::shared_ptr而不是boost::shared-ptr构建boost库吗
- std::dynamic_pointer_cast从基到派生的std::shared返回NULL
- QSharedPointer VS std::tr1::shared_ptr VS boost::tr1::shared