c – 移动构造函数和初始化列表

前端之家收集整理的这篇文章主要介绍了c – 移动构造函数和初始化列表前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我想为某个类型实现移动构造函数(没有复制构造函数),这个类型需要是boost :: unordered_map中的值类型.我们称之为复合型.

Composite具有以下签名:

struct Base
{
  Base(..stuff,no default ctor) : initialization list {}
  Base(Base&& other) : initialization list {} 
}

struct Composite
{
  Base member;
  Composite(..stuff,no default ctor) : member(...) {}
  Composite(Composite&& other) : member(other.member) {} // <---- I want to make sure this invokes the move ctor of Base
}

我想写这个,所以boost :: unordered_map< Key,Composite>不需要复制构造函数,只使用移动构造函数.如果可能的话,我不想在Composite的移动构造函数的初始化列表中使用Base的复制构造函数.

这可能吗?

解决方法

说成员(std :: move(other.member)).

作为一个黄金法则,无论何时你通过右值引用来获取东西,你需要在std :: move中使用它,并且每当你通过通用引用(即使用&&推导出的模板类型)时,你需要在里面使用它的std ::前进.

猜你在找的C&C++相关文章