Anfangs dachte ich, dass move constructor den temporären Objektdestruktor nicht aufrufen würde, aber wenn ich es versuche, ruft er den Destruktor auf. Wenn wir also die Daten von move constructor stehlen, bekomme ich doppelten Löschfehler.Move constructor und double delete
#include <iostream>
using namespace std;
class A
{
public:
A()
: name("default")
{
cout<<"i am default\n";
data = new char[20];
}
A(A&& t)
: name("move")
{
data = t.data;
cout<<"i am move\n";
}
~A()
{
delete data;
cout<<"I am done:"<<name<<endl;
}
char * data;
string name;
};
A getA()
{
A obj;
return obj;
}
int main()
{
A test(std::move(getA()));
}
Nun, Ihr Umzug Konstruktor gebrochen ist. Aber was ist deine Frage? – juanchopanza
Sie * sicher * Sie haben diese Daten gestohlen? Ich bin mir ziemlich sicher, dass dein Originalobjekt immer noch glaubt, dass es ihm gehört, zumal du nichts getan hast, um es anders in deinem mv-ctor zu erzählen. – WhozCraig
Ich bekomme doppelte Fehler löschen, wenn ich dies ausführen, was wird der Grund sein? –