Этот отличается, потому что он не просит по международной конверсии rValue в lvalue, но избирательно делает это для классов, для которых, возможно, эта преобразование имеет смысл, чтобы быть автоматическим. < /p>
C ++, Function void v (A & p> < /> . в LVALUE.
возможно ли для автоматического смены RVALUE?
Код: Выделить всё
#include
#include
struct A {
operator A&() && {
return *this;
}
void mutate() {...}
};
< /code>
Это создает предупреждение компилятора, «преобразование» в ссылку на тот же тип никогда не будет использовать преобразование типа ». Но, по крайней мере, оператор составлен и работает, за исключением того, что его необходимо явно вызвать с полным.void f(A& a) { a.mutate(); }
A make_A() { return A{}; }
int main() {
A a;
f(a); // ok
f(make_A().operator A&()); // ok
f(make_A()); // does not compile, implicit conversion to A& doesn't work
f(std::move(a)); // does not compile
}
Есть ли улов или обходной путь для достижения этого?
Подробнее здесь: https://stackoverflow.com/questions/797 ... -of-itself
Мобильная версия