我想为某个类型实现移动构造函数(没有复制构造函数),这个类型需要是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 ::前进.