Maison > développement back-end > C++ > le corps du texte

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

Susan Sarandon
Libérer: 2024-11-01 17:44:02
original
358 Les gens l'ont consulté

 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>
Copier après la connexion

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>
Copier après la connexion

ou

<code class="cpp">Y& Y::operator=(Y&);</code>
Copier après la connexion

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>
Copier après la connexion

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!

source:php.cn
Déclaration de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!