首页 > 解决方案 > 具有字符串成员的类的 C++ 移动构造函数

问题描述

我用以下代码编写了一个类:

class Test {
public:
...
    Test( const Test &&that ) : i(that.i), s(std::move(that.s)) {
        cout << "move contructor." << endl;
    }
...
private:
    int i;
    std::string s;
};

如果我反汇编生成的代码,我会看到:

        .type   Test::Test(Test const&&), @function
Test::Test(Test const&&):
...
       call    std::remove_reference<std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> > const&>::type&& std::move<std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> > const&>(std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> > const&)
        movq    %rax, %rsi
        movq    %rbx, %rdi
.LEHB3:
        call    std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> >::basic_string(std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> > const&)@PLT

调用它让我感到惊讶,basic_string<...>::basic_string( basic_string<...> const&)因为我希望调用 basic_string 的移动构造函数basic_string<...>::basic_string( basic_string<...> &&)

我以不正确的方式实现移动构造函数?

标签: c++move-semantics

解决方案


对 const 类型的右值引用不是很有用。他们说代码可以从对象中窃取,但必须在不改变其价值的情况下这样做?

由于std::string没有string(const string&&)移动构造函数,重载解析只能使用string(const string&)复制构造函数。

普通的移动构造函数不使用const

Test( Test &&that ) : i(that.i), s(std::move(that.s)) {
    std::cout << "move constructor." << std::endl;
}

推荐阅读