- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我要实现的目标:我正在尝试实现类似于 Java 枚举的东西(即具有一些附加功能的枚举)。我想出了一个使用两个类的解决方案,其中一个类表示一个值,另一个类作为可能值的枚举,使用静态变量来表示每个值。我希望它成为枚举的真正替代品,包括在模板实例化中使用枚举值的可能性。为此,枚举值需要是常量表达式 (constexpr)。但是,我不确定我是否正确使用了 constexpr。
这是我想出的代码:
class EnumType {
public:
enum Enum {val_A, val_B, val_C};
friend class EnumTypeList;
EnumType()
: m_ID(val_A), m_foo(0) {}
constexpr operator Enum() const {return m_ID;};
constexpr unsigned int getFoo() const {return m_foo;};
protected:
constexpr EnumType(const Enum v, const int foo)
: m_ID(v), m_foo(foo) {}
private:
Enum m_ID;
int m_foo;
};
class EnumTypeList {
public:
static constexpr EnumType A = EnumType(EnumType::val_A, 5);
static constexpr EnumType B = EnumType(EnumType::val_B, 4);
static constexpr EnumType C = EnumType(EnumType::val_C, 8);
};
EnumType
类保存了每个值的信息并提供了一些额外的功能(这里它存储了可以使用 getFoo()
函数访问的额外值 m_foo) .枚举本身由包含静态 constexpr 变量的 EnumTypeList
表示,其中每个变量代表枚举的一个可能值。此代码允许我使用 EnumTypeList
中的变量代替 EnumType::Enum。
即使在模板中,如以下代码:
template <EnumType::Enum T>
class Test {
public:
void test() {
std::cout << "Enum is not A" << std::endl;
}
};
template <>
class Test<EnumType::val_A> {
public:
void test() {
std::cout << "Enum is A" << std::endl;
}
};
int main() {
Test<EnumTypeList::A> a;
a.test();
Test<EnumTypeList::B> b;
b.test();
// this shouldn't compile
/*EnumType x = EnumTypeList::C;
Test<x> c;
c.test();*/
}
这如我所料 – 我可以使用 EnumTypeList
中的值代替 EnumType::Enum
在模板实例化中如上所示,但我不能使用 EnumType x = EnumTypeList::C;
虽然代码在 gcc 和 clang 下正确编译且没有任何警告,但我不确定我是否正确使用了 constexpr。问题是虽然 EnumType
构造函数和转换运算符 operator Enum()
是 constexpr,但它们都访问变量 m_ID
和 m_foo
不是常量(因为我需要赋值运算符)。
最佳答案
这很好,文字类型的成员是允许修改的。
为了在常量表达式中使用该类型,您必须使用常量参数构造它,但这没关系,因为您这样做了;
static constexpr EnumType A = EnumType(EnumType::val_A, 5);
构造的对象是一个有效的常量表达式,因此可用于初始化constexpr
变量A
。您不修改对象的成员,因此它们是否可修改并不重要。
Clang 对常量表达式特别严格,如果你做错了什么就会报错。
这个对象可以用在需要常量表达式的地方:
constexpr EnumType A5(EnumType::val_A, 5);
例如
constexpr int i = A5.getFoo();
这个对象不能:
EnumType A6(EnumType::val_A, 6);
constexpr int i = A6.getFoo(); // error
关于c++ - constexpr 的使用是否对非常量成员有效,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17361103/
在 ubuntu gcc 8.0 中: void bar(){} constexpr int foo(int a) { if (a <=0 ) bar(); retur
考虑一个在运行时只包装一个值的类: template class NonConstValue { public: NonConstValue(const Type& val)
在试验 constexpr 函数和模板(以及非类型模板参数)时,我偶然发现了一个现象,我无法理解是哪条规则使它生效。 所以根据 constexpr-s 的规则,我的问题本质上是“为什么会发生这种情况”
我正在阅读 Nicolai M. Josuttis 所著的“C++ 17 The Complete Guide”一书,无法理解以下示例 auto squared1 = [](auto val) con
(使用 g++ 7.0 主干。) 给定以下“类型到值包装”实用程序... template struct type_wrapper { using type = T; }; // "Wraps" a
我编写了一些代码,它能够根据调用站点提供与给定函数关联的字符串(通过函数指针和并行数组的tuple)来分派(dispatch)给函数。 dispatch 函数不直接接受字符串,而是接受 Callabl
如果我想使用一些方便的东西,比如 make_array 我没有机会先声明我的数组,然后再像“早些时候”那样进行定义,因为我的 var 类型不可用定义前。 所以我找到了这个答案: Undefined r
使用 gcc (HEAD 7.0.0 201612) 我惊讶地发现这有效: constexpr long value(const char *definition) { if (definit
我有这个片段。 #include #include struct JustStr { JustStr(const std::string& x) : val(x) {} stati
我找不到任何关于新 C++17 if 初始化语法的信息和“constexpr if”在: http://open-std.org/JTC1/SC22/WG21/docs/papers/2016/p01
考虑以下函数: template auto concatenate(std::array &data1, std::array &data2) { std::array result;
假设我有以下对象: #include class Foo { public: constexpr Foo() {}; constexpr std::string foo() cons
我正在尝试使用 https://github.com/gdelugre/literal_ipaddr它说它是一个 C++17 constexpr implementation of inet_addr
我想重新定义unique_ptr用一个特殊的析构函数。因此,我使用以下代码尝试模仿 unique_ptr 的一些构造函数.遗憾constexpr施 worker 员拒绝 build ,我不知道为什么。
我想用结构名称的哈希值初始化一个结构成员。 constexpr uint32_t myHash(const char* const data) { //Some code for hash r
我正在尝试编译 C++ 库(使用 gcc 5.3.1-14ubuntu2)并遇到此类错误: > In file included from > /root/pitchfork/workspace/un
设置: 我有一个使用 SIMD 内部函数的函数,我想在一些 constexpr 函数中使用它。 为此,我需要将其设为 constexpr。但是,SIMD 内在函数没有标记为 constexpr,编译器
这是一个简化的代码示例,旨在生成任意值序列(在 std::iota 的意义上)和在它们之上的不同类别的迭代器: struct delta { template void inc(I&
考虑以下函数: template auto concatenate(std::array &data1, std::array &data2) { std::array result;
我偶然发现了调用非 constexpr 函数的 constexpr 模板函数:在以下代码段中,由于调用了非 constexpr set,bar 无法按预期编译,但 foo 可以编译。谁能告诉我 foo
我是一名优秀的程序员,十分优秀!