首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为什么std::condition_variable没有被锁类型模板化?

为什么std::condition_variable没有被锁类型模板化?
EN

Stack Overflow用户
提问于 2015-05-08 11:41:43
回答 1查看 208关注 0票数 1

无论是否锁定互斥对象,在调试模式下具有断言的能力(开销相当小)是非常有用的。考虑到已知的选项,由于管理费用低,我选择了子类

子类的接口是std::mutex的一个超集,因此大多数事情都与它很好地工作。例如,std::unique_lock被模板化,以利用具有特定接口的任何锁类型。

问题在于std::condition_variable,特别是wait成员,例如:

代码语言:javascript
复制
template<class Predicate>
void wait(std::unique_lock<std::mutex> &lock, Predicate pred);

可以看出,该方法需要非常特定的unique_lock/mutex组合。不幸的是,Liskov原理没有扩展到container<derived>被转换为container<base>

我不明白

  1. 为什么会这样?

即使目的是强制使用std::unique_lock,为什么不能使用以下内容:

代码语言:javascript
复制
template<class Predicate, class Lock=std::mutex>
void wait(std::unique_lock<Lock> &lock, Predicate pred);
  1. 怎样才能合理地绕过这一问题?

编辑

正如@Lingxi所解释的,以及@T.C进一步指出的,这里绝对正确和非常简单的解决方案是使用condition_variable_any,它是为类似这样的东西而设计的。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-05-08 11:49:21

试试std::condition_variable_any。它有一个wait的模板版本。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30122982

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档