std :: move с внутренними объектами — нет соответствия для вызова

Код ниже не компилируется.
Главный:

#include "preset.h"int main(int argc, char *argv[])
{
QCoreApplication a(argc, argv);
SomeA a1(4);
WrapA wA1(a1);
WrapA wA2(std::move(wA1)); //fails to compile here
return a.exec();
}

preset.h:

    #include <QDebug>
class SomeA
{
public:
SomeA(int l){val = l;}
SomeA(const SomeA& original): val(original.val){qDebug()<<"sA copy;";}
SomeA(SomeA&& original){std::swap(val, original.val); qDebug()<<"sA move;";}
SomeA operator = (const SomeA&);
int val{0};
};

class WrapA
{
public:
WrapA(SomeA obj): aObj(obj){}
WrapA(const WrapA& original): aObj(original.aObj) {qDebug()<<"wA copy";}
WrapA(WrapA&& original) {aObj(std::move(original.aObj)); qDebug()<<"wA move";} //no match for call (SomeA)(std::remove_reference<SomeA&>::type)
SomeA aObj{0};
};

Я полагаю, что std :: move не приводится от ссылки к rvalue. Есть идеи как добиться такого глубокого хода c-tor? Я думаю, что я что-то упускаю, но не могу понять, что именно

0

Решение

 WrapA(WrapA&& original) {aObj(std::move(original.aObj)); qDebug()<<"wA move";}

Вы хотели написать это как

 WrapA(WrapA&& original) : aObj(std::move(original.aObj)) {qDebug()<<"wA move";}

Смотрите также конструктор копирования для справки.

(Должен быть уже подобный вопрос к этому, но я не могу найти это.)

0

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]