传递临时值时不调用移动构造函数

问题描述

class Bar
{
    public:
        Bar() {}
        Bar(Bar&& b)
        {
            cout << "move\n";
        }
};

int main(int argc,char* argv[])
{
    Bar b(Bar());
    return 0;
}

Bar() 是右值吗?如果是这样,为什么不调用 Bar(Bar&& b)? 仅当我通过写入 Bar b(move(Bar()) 进行更改时,才会调用 move constr。

但我认为 Bar() 已经是一个右值。有人可以解释这种行为吗?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)