Maison >développement back-end >C++ >Pouvez-vous attribuer à des références Rvalue un type de classe ? Un paradoxe expliqué.

Pouvez-vous attribuer à des références Rvalue un type de classe ? Un paradoxe expliqué.

Susan Sarandon
Susan Sarandonoriginal
2024-11-01 17:44:02500parcourir

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

Attribution à des références Rvalue d'un type de classe : un paradoxe résolu

Dans le domaine de C, la distinction entre lvalues ​​et rvalues ​​est primordiale. Les valeurs L représentent des objets avec des emplacements mémoire qui peuvent être modifiés, tandis que les valeurs R incarnent des objets temporaires ou des constantes qui ne le peuvent pas. Cependant, un extrait de code intrigant soulève des questions sur cette division fondamentale :

<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>

Pourquoi ce code est-il compilé ? La rvalue renvoyée par le constructeur n'est-elle pas éphémère et donc impropre à l'affectation ?

La clé pour comprendre ce paradoxe réside dans l'opérateur d'affectation implicite en C . Lorsque l'opérateur d'affectation n'est pas explicitement défini pour une classe, le compilateur synthétise un opérateur d'affectation par défaut. Surtout, cet opérateur synthétisé peut être applicable aux rvalues ​​dans certains cas.

C'est là que le mot-clé explicite joue un rôle. Dans l'exemple donné, la classe Y ne déclare pas d'opérateur d'affectation, le compilateur en génère donc un. Le mot-clé explicite empêche les conversions implicites à partir des rvalues, mais il n'empêche pas l'opérateur d'affectation synthétisé d'être applicable aux rvalues.

Ainsi, dans notre code, l'opérateur d'affectation synthétisé :

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

ou

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

peut être invoqué avec la rvalue Y(1) sur le côté gauche. Cela permet à l'affectation de se poursuivre, même si Y(1) est une valeur r.

Pour empêcher l'affectation à des objets temporaires, on peut déclarer explicitement l'opérateur d'affectation avec un qualificatif de référence (&) :

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

Dans ce cas, l'opérateur d'affectation ne sera pas synthétisé et tenter de l'attribuer à une rvalue entraînera une erreur de compilation.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn