Heim >Backend-Entwicklung >C++ >Können Sie Rvalue-Referenzen vom Klassentyp zuweisen? Ein erklärtes Paradoxon.

Können Sie Rvalue-Referenzen vom Klassentyp zuweisen? Ein erklärtes Paradoxon.

Susan Sarandon
Susan SarandonOriginal
2024-11-01 17:44:02500Durchsuche

 Can You Assign to Rvalue References of Class Type?  A Paradox Explained.

Zuweisen von R-Wert-Referenzen des Klassentyps: Ein gelöstes Paradoxon

Im Bereich C ist die Unterscheidung zwischen L-Werten und R-Werten von größter Bedeutung. L-Werte stellen Objekte mit Speicherorten dar, die geändert werden können, während R-Werte temporäre Objekte oder Konstanten verkörpern, die nicht geändert werden können. Ein interessanter Codeausschnitt wirft jedoch Fragen zu dieser grundlegenden Kluft auf:

<code class="cpp">class Y {
public:
    explicit Y(size_t num = 0) {}
};

int main() {
    Y(1) = Y(0); // Here lies the enigma!
    return 0;
}</code>

Warum wird dieser Code kompiliert? Ist der vom Konstruktor zurückgegebene R-Wert nicht kurzlebig und daher für die Zuweisung ungeeignet?

Der Schlüssel zum Verständnis dieses Paradoxons liegt im impliziten Zuweisungsoperator in C. Wenn der Zuweisungsoperator nicht explizit für eine Klasse definiert ist, synthetisiert der Compiler einen Standardzuweisungsoperator. Entscheidend ist, dass dieser synthetisierte Operator in einigen Fällen auf R-Werte anwendbar ist.

Hier spielt das explizite Schlüsselwort eine Rolle. Im gegebenen Beispiel deklariert die Y-Klasse keinen Zuweisungsoperator, daher generiert der Compiler einen. Das Schlüsselwort „explicit“ verhindert implizite Konvertierungen von R-Werten, verhindert jedoch nicht, dass der synthetisierte Zuweisungsoperator auf R-Werte anwendbar ist.

Daher gilt in unserem Code der synthetisierte Zuweisungsoperator:

<code class="cpp">Y& Y::operator=(Y const&);</code>

oder

<code class="cpp">Y& Y::operator=(Y&);</code>

kann mit dem R-Wert Y(1) auf der linken Seite aufgerufen werden. Dadurch kann die Zuweisung fortgesetzt werden, auch wenn Y(1) ein R-Wert ist.

Um die Zuweisung an temporäre Objekte zu verhindern, kann man den Zuweisungsoperator explizit mit einem Ref-Qualifizierer (&) deklarieren:

<code class="cpp">class Y {
public:
    explicit Y(std::size_t num = 0);
    Y& operator=(Y const&) & = default;
};</code>

In diesem Fall wird der Zuweisungsoperator nicht synthetisiert und der Versuch, ihn einem R-Wert zuzuweisen, führt zu einem Kompilierungsfehler.

Das obige ist der detaillierte Inhalt vonKönnen Sie Rvalue-Referenzen vom Klassentyp zuweisen? Ein erklärtes Paradoxon.. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn