c++ - initializer_list<T> 对 T 的赋值运算符要求

标签 c++ c++11 initializer-list

我想知道是否 initializer_list<T>要求 T 有一个赋值运算符。以下

struct Foo
{
    Foo& operator=( const Foo& ) = delete;
};

std::vector<Foo> f = { Foo( ), Foo( ) };

在 clang 3.4.2 上编译但在 Visual Studo 2013 上失败并显示 "error C2280: 'Foo &Foo::operator =(const Foo &)' : attempting to reference a deleted function" .我假设 clang 在这里是正确的,但想检查是否不需要 T 可以分配。

最佳答案

std::initializer_list<T>不需要 T可以任何方式分配,因为复制 std::initializer_list objects 是浅层的——它不复制底层数据。

您收到错误是因为 MSVC 2013(及更低版本)不支持自动生成移动构造函数和移动赋值运算符。所以错误实际上来自std::vector试图从初始化列表中复制,而不是从初始化列表本身复制。

为什么触发错误仍然是一个问题,因为 std::vector构造函数 std::initializer_list只要求类型为 EmplaceConstructible可能还有 MoveInsertable ,两者都不使用赋值。

关于c++ - initializer_list<T> 对 T 的赋值运算符要求,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25642892/

相关文章:

c++ - 定义 []= 运算符

c++ - 错误 'extern' 及更高版本 'static'

c++ - 根据 move 构造函数实现复制赋值运算符

c++ - 具有不合格名称 : C++0x draft n3290 的名称查找

c++ - 如何编写正确的 std::initializer_list 构造函数

c++ - 将数字数据写成二进制还是写成二进制?

c++ - C 样式转换是否添加程序集(代码)或仅供编译器了解情况?

c++ - 从不可复制类型创建 std::initializer_list

c++ - 我可以 std::find stringstream 中的字符串吗?

c++ - 使用成员初始化器列表会使初始化速度稍微快一些吗?