Код: Выделить всё
class A
{
public:
A&& func(A& rhs)
{
//return rhs;
return std::move(rhs); //returning A&&
}
};
Код: Выделить всё
class A
{
public:
A func(A& rhs)
{
//return rhs;
return std::move(rhs); //returning A&&
}
};
Обновление:
Думаю, я получил ответ, ну, по крайней мере. , тот имеет смысл моего маленького мозга. X и X&& — это два разных типа, но причина, по которой они работают, заключается в том, что преобразование действительно доступно через конструктор перемещения по умолчанию. Я изменил фрагмент на этот, и компиляция начала давать сбой:
Код: Выделить всё
class A
{
public:
A(const A& rhs){};
A(A&& rhs) = delete; //move constructor deleted
A func(A& rhs)
{
//return rhs;
return std::move(rhs);
}
};
(27): error C2280: 'A::A(A &&)': attempting to reference a deleted function
Спасибо всем за ваш вклад. От C++ у меня кружится голова.
Подробнее здесь: https://stackoverflow.com/questions/791 ... -reference
Мобильная версия