Theo: constexpr static data member giving undefined reference error thành viên lớp constexpr tĩnh phải đáp ứng hai yêu cầu:khởi thống nhất tĩnh thành viên 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;
}
- Khởi tạo bên trong định nghĩa lớp (vì nó là constexpr)
- Defined ngoài định nghĩa lớp (vì nó là tĩnh)
Nếu tôi thay đổi 1. thành đồng nhất initiali zation
template <typename Tp>
struct wrapper {
static constexpr auto value = Tp{}; // uniform initialization
};
template<typename Tp>
constexpr Tp wrapper<Tp>::value;
biên dịch phàn nàn tờ khai về mâu thuẫn:
$ 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{};
và cũng về việc thiếu initializer:
prog.cc:7:31: error: declaration of 'constexpr const auto wrapper<Tp>::value' has no initializer
Loại bỏ mâu thuẫn 2. Định nghĩa kết thúc, như mong đợi, với lỗi mối liên kết:
In function `main': prog.cc:(.text+0x8): undefined reference to `wrapper<foo>::value'
Ví dụ mã online.
Có thể/hợp pháp để sử dụng khởi tạo đồng bộ cho các thành viên lớp constexpr tĩnh không?
này có cái gì để làm với các mẫu tham số: Nó hoạt động như mong đợi nếu loại các thành viên dữ liệu tĩnh không phụ thuộc vào các mẫu tham số, như 'giá trị constexpr auto tĩnh = int {}; ' – dyp
lớp trình bao bọc này thực sự là sự thay thế cho mẫu biến C++ 14 trong gcc <5.0, vì vậy tham số mẫu là phải –
Bạn có cần sử dụng' auto' không? –