为什么编译器认为我在尝试从类型Container
的对象转换为以下代码中的MoveTest
类型的对象?为什么被支撑的构造函数被转发到move_things
变量?用{}
替换()
当然可以解决问题
#include <iostream>
#include <array>
using namespace std;
static constexpr int NUMBER{2};
class MoveTest {
public:
MoveTest(const MoveTest&) {
cout << "MoveTest(const MoveTest&)" << endl;
}
MoveTest(MoveTest&&) {
cout << "MoveTest(MoveTest&&)" << endl;
}
MoveTest() {
cout << "MoveTest()" << endl;
}
};
class Container {
public:
Container() = default;
Container(Container&&) = default;
Container(const Container&) = default;
std::array<MoveTest, NUMBER> move_things;
};
int main() {
Container container;
__attribute__((unused)) Container another_one{std::move(container)};
return 0;
}
我得到的错误是以下
Could not convert ‘std::move<Container&>((* & container))’ from ‘std::remove_reference<Container&>::type {aka Container}’ to ‘MoveTest`
这是否意味着统一初始化语法不再是具有std::array
的任何类的选项?
我使用的编译器和版本是
g++ (GCC) 4.8.5 20150623 (Red Hat 4.8.5-4)