クラス型の右辺値参照に代入できますか? パラドックスの説明。
クラス型の右辺値参照への代入: 解決されたパラドックス
C の領域では、左辺値と右辺値の区別が最も重要です。左辺値は変更可能なメモリ位置を持つオブジェクトを表しますが、右辺値は変更できない一時オブジェクトまたは定数を具体化します。しかし、興味深いコード スニペットによって、この基本的な相違点について疑問が生じます。
<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>
なぜこのコードはコンパイルされるのでしょうか?コンストラクターによって返される右辺値は一時的であり、代入には適していませんか?
このパラドックスを理解する鍵は、 C の暗黙的な代入演算子にあります。代入演算子がクラスに対して明示的に定義されていない場合、コンパイラはデフォルトの代入演算子を合成します。重要なのは、この合成された演算子は場合によっては右辺値に適用できることです。
ここで明示的なキーワードが役割を果たします。この例では、Y クラスは代入演算子を宣言していないため、コンパイラが代入演算子を生成します。 Explicit キーワードは右辺値からの暗黙的な変換を防ぎますが、合成された代入演算子が右辺値に適用されることを妨げません。
したがって、コードでは、合成された代入演算子は次のようになります。
<code class="cpp">Y& Y::operator=(Y const&);</code>
または
<code class="cpp">Y& Y::operator=(Y&);</code>
は、左側の右辺値 Y(1) を使用して呼び出すことができます。これにより、Y(1) が右辺値であっても代入を続行できます。
一時オブジェクトへの代入を防ぐために、参照修飾子 (&) を使用して代入演算子を明示的に宣言できます:
<code class="cpp">class Y { public: explicit Y(std::size_t num = 0); Y& operator=(Y const&) & = default; };</code>
この場合、代入演算子は合成されず、右辺値に代入しようとするとコンパイル エラーが発生します。
以上がクラス型の右辺値参照に代入できますか? パラドックスの説明。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











C言語関数によって返される値の種類は何ですか?返品値を決定するものは何ですか?

STL(ソート、検索、変換など)のアルゴリズムを効率的に使用するにはどうすればよいですか?
