[英]How std::initializer_list Works?
我目前正在研究 c++11 我不明白 std::initializer_list 的构造函数它看起来像这样
constexpr initializer_list() noexcept : _First(nullptr), _Last(nullptr) {}
constexpr initializer_list(const _Elem* _First_arg, const _Elem* _Last_arg) noexcept
: _First(_First_arg), _Last(_Last_arg) {}
但它是如何工作的
std::initializer_list<int> v{1,2,3,4,5,6,7,8,9,0};
我试过这个
constexpr init(const _Elem* _First_arg, const _Elem* _Last_arg) noexcept
: _First(_First_arg), _Last(_Last_arg) {}
但这显示错误
init<int> ob{1,2,3,4,5,6,7,8,9,0}; //this shows error
note: candidate: 'constexpr init<_Elem>::init(const _Elem*, const _Elem*) [with _Elem = int]'
constexpr init(const _Elem* _First_arg, const _Elem* _Last_arg) noexcept
^~~~
note: candidate expects 2 arguments, 10 provided
我将 {} 更改为 () 喜欢
std::initializer_list<int> v(1,2,3,4,5,6,7,8,9,0);
这显示错误。
1)std::initializer_list 是如何工作的?
2) {} 后面是什么?
谢谢。
std::initializer_list
是特殊的。 不可能以相同的方式编写可以用作构造函数参数的 class。 语言规则指定std::initializer_list
如何工作 - 或者更确切地说,接受std::initializer_list
的构造函数,即初始化列表构造函数如何工作。 语言实现使其按规定工作。
PS 标识符(例如_Elem
)保留给语言实现。 由于您的 class init
不是语言实现的一部分,因此使用保留标识符会导致未定义的行为。 不要使用保留的标识符。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.