要求包含 <initializer_list>?
What is the rationale for requiring inclusion of <initializer_list>?
From [dcl.init.list]
模板
std::initializer_list
不是预定义的;如果在使用std::initializer_list
之前未包含标头(即使是未命名类型的隐式使用(,则程序格式不正确。
既然std::initializer_list
无论如何都是编译器的特殊情况,为什么它不被视为语言的一流语法?
我对一些可能性及其反驳的看法:
命名空间污染
可以像std::size_t
一样解决,包含标头只引入了标识符。
请注意,即使不包含任何标头,auto sz = sizeof(0);
的格式也很好,而不是auto il = {1, 2, 3};
格式不正确。
编译开销
std::initializer_list
的libstdc++实现实际上少于50行,不依赖于其他标头。这能有多大的开销?
似乎背后
没有理性。也许当时希望进一步的语言决议和修改允许实现,但现在看来这并不真实。
无论如何,可以在此处找到有关该论点的进一步阅读。
相关文章:
- 使用std::multimap迭代器创建std::list
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- 如何在 C 中正确使用 libiconv 使其不会报告"Arg list too long"?
- C++中带有List类的迭代器Segfault
- 使用"std::unordereded_map"映射到"std::list"对象
- GCC对可能有效的代码抛出init list生存期警告
- 使用std::list创建循环链表
- 重载Singly Linked List中的赋值运算符
- EASTL矢量<向量<int>>连续的
- '[](std::list& list)<int>{return std::move(list)}(list)' 是否保证将 'list' 留空?
- 如果 KEY 是 std::list 或 std::vector 而不是值,那么 std::map 的默认行为是什么?
- 为什么这个 std::queue/指向结构的指针列表直到 List.Size() == 0 才释放内存?
- "std::list::splice(std::const_iterator pos, std::list&& other)"是否保证将"其他"留空?
- 从嵌套循环中的 std::list 中删除将返回访问冲突
- QStringList vs list<shared_ptr<QString>> 性能比较C++
- 包含 std::list 的结构体的 C++ 初始化
- 在C++中使用 Catch 测试框架编译错误"error: expected ';' at end of declaration list"
- C++ assigment std::list:<typename>:itrator 在 main 中工作,但在方法中它不起作用
- opencv 2.4.7在iOS错误背景_segm.hpp #include&lt; list&gt;未找到
- 在修改列表后,std :: list&lt; t&gt; :: end()的值是否会更改