微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

static_cast 从底层类型值枚举类并切换以获取编译器帮助

如何解决static_cast 从底层类型值枚举类并切换以获取编译器帮助

假设我有一个枚举:

enum class Thing : std::uint8_t {
  Foo = 21,Bar = 42,Baz = 1
};

我想将“原始”值(底层类型)转换为该枚举的值,并通过错误处理捕获不是“事物”的值。我可以使用 if (raw_value == static_cast<std::uint8_t>(Thing::Foo)) 之类的检查,然后使用 else 进行错误处理,但随后 我可能会忘记,例如 Thing::Baz。但是,当我切换 Thing 类型的值时,我的编译器(可能是大多数现代编译器)警告我未处理的枚举值(“枚举值 Baz 未在 switch 中处理”)。>

所以我想出了这个:

Thing thingFromUInt8(std::uint8_t const b) {
  Thing const t = static_cast<Thing>(b);
  switch (t) { // If I'd add Thing::Frob but forget it here I get a warning
    case Thing::Foo:
    case Thing::Bar:
    case Thing::Baz:
      return t;
  }
  throw std::runtime_error("That's not a thing...");
}

问题:

  • 这是“合法的”C++(C++11 及更高版本)吗?
  • 如果是,它有什么缺点吗?

解决方法

这是合法的 C++。

缺点是违反 DRY,但很难避免。

中,我们将进行反射并能够生成等效的代码(无需依赖编译器警告来确保我们没有遗漏任何内容)。反射语法仍然在不断变化,但我读过的每个版本都能够解决这个问题。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。