[英]Ensuring that a member variable is moved, if the object is a rvalue
请考虑以下代码:
class A
{
public:
A(/* params */) {
// Fill m_data depending on params
}
std::vector<double> get_data() const noexcept {
return m_data;
}
private:
std::vector<double> m_data;
};
std::vector<double> get_data() {
return A{/* suitable params */}.get_data();
}
我想要的是,将m_data
移动到函数get_data()
的调用者,即,不应制作任何副本。
我如何确定是这种情况? 显然, A{/* suitable params */}
是一个右值。 因此,在这种情况下,它的成员变量m_data
是一个右值。 因此,添加另一个成员函数是否足够
std::vector<double> get_data() && noexcept {
return std::move(m_data);
}
使用最新版本的编译器(阅读:不是MSVC 2013),您可以在rvalue与lvalue上重载。
class A {
// ...
std::vector<double> get_data() && noexcept {
return std::move(m_data);
}
std::vector<double> get_data() const & { // not noexcept, could throw
return m_data;
}
// ...
};
另外,左值版本可以返回对向量的const引用,并且为noexcept,但这意味着您要暴露一个事实,即某个地方有一个物理变量,这将阻止您在以后的重构中进行更改。
请注意,您不能拥有一个没有ref限定符的函数,而另一个函数具有ref限定符,否则它们具有相同的名称和参数。 这是模棱两可的,编译器应该抱怨。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.