首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为什么folly::future BrokenPromise使const char*构造函数显式?

为什么folly::future BrokenPromise使const char*构造函数显式?
EN

Stack Overflow用户
提问于 2018-06-01 12:00:37
回答 1查看 289关注 0票数 0

我注意到facebook folly::future库中的BrokenPromise定义,我不能理解这里显式BrokenPromise(const char* type)构造函数的用途?有必要吗?

代码语言:javascript
复制
class FOLLY_EXPORT BrokenPromise : public PromiseException {
 public:
  explicit BrokenPromise(const std::string& type)
      : PromiseException("Broken promise for type name `" + type + '`') {}

  explicit BrokenPromise(const char* type) : BrokenPromise(std::string(type)) {}
};

https://github.com/facebook/folly/blob/master/folly/futures/Promise.h#L47

EN

回答 1

Stack Overflow用户

发布于 2018-06-01 12:08:16

%1参数构造函数是转换构造函数。如果操作不是简单的重新解释(而且是无损的),大多数编码标准都会说你把它说得很清楚。

字符串的BrokenPromise不仅仅是对字符串的无损重新解释。因此,显式。

避免隐式转换还有其他原因;例如,如果0是隐式的,则可能会意外地从char const*构造BrokenPromise

非显式的情况可能是从单个浮点数构造一个复数;实数是复数的一个子集。

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

https://stackoverflow.com/questions/50635916

复制
相关文章

相似问题

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