プライベート コンストラクターがプライベート コンストラクターではない場合は何ですか?
C では、コンストラクターをプライベートにすることが、オブジェクトの作成を防ぐ簡単な方法のように思えます。クラスの外で。ただし、デフォルトのコンストラクターがプライベートと宣言されている場合、予期しない動作が発生します。
次のコードを考えてみましょう:
class C { C() = default; }; int main() { C c; // Error: Private constructor auto c2 = C(); // Error: Private constructor }
驚くべきことに、このコードはプライベートのデフォルト コンストラクターが原因でコンパイルに失敗します。ただし、次のコード:
class C { C() = default; }; int main() { C c{}; // Compiles auto c2 = C{}; // Compiles }
は正常にコンパイルされます。
この奇妙な動作の理由は C 標準にあります。 8.4.2/5 [dcl.fct.def.default] によれば、関数が最初の宣言で明示的にデフォルトに設定されている場合、その関数はユーザーによって提供されません。したがって、最初の例では、デフォルトのコンストラクターはユーザーが提供しません。
このユーザー提供のコンストラクターがないため、クラス C は 8.5.1/1 [dcl.init.aggr] に従って集約になります。これ:
集約の場合、braced-init 構文はコンストラクター呼び出しとみなされ、これが、後者のコード スニペットで成功する理由です。
以上がC でプライベートのデフォルト コンストラクターがオブジェクトの作成を妨げるのに、括弧付き初期化は機能するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。