根据: constexpr static data member given undefined reference error static constexpr类成员必须满足两个要求:
template <typename Tp>
struct wrapper {
static constexpr Tp value{}; // 1
};
template<typename Tp>
constexpr Tp wrapper<Tp>::value; // 2
struct foo {
};
int main() {
auto const& x = wrapper<foo>::value;
(void)x;
}
- 在类定义中初始化(因为它是 constexpr)
- 在类定义之外定义(因为它是静态的)
如果我将 1. 更改为统一初始化
template <typename Tp>
struct wrapper {
static constexpr auto value = Tp{}; // uniform initialization
};
template<typename Tp>
constexpr Tp wrapper<Tp>::value;
编译器抱怨声明冲突:
$ g++ prog.cc -Wall -Wextra -std=c++1z -pedantic
prog.cc:7:31: error: conflicting declaration 'constexpr const Tp wrapper<Tp>::value' constexpr Tp wrapper<Tp>::value;
prog.cc:3:29: note: previous declaration as 'constexpr const auto wrapper<Tp>::value' static constexpr auto value = Tp{};
还有关于缺少初始化程序:
prog.cc:7:31: error: declaration of 'constexpr const auto wrapper<Tp>::value' has no initializer
删除冲突的 2. 定义按预期结束,但出现链接器错误:
In function `main': prog.cc:(.text+0x8): undefined reference to `wrapper<foo>::value'
在线代码示例。
对静态 constexpr 类成员使用统一初始化是否可能/合法?