在std :: move

时间:2016-07-07 19:48:39

标签: c++ c++11 stdarray uniform-initialization

为什么编译器认为我在尝试从类型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)

0 个答案:

没有答案