C がスコープ解決演算子を導入した理由
Java と比較して、C は、依存する代わりに独自のスコープ解決演算子 (::) を提供します。ドット (.) 演算子のみ。 Java は別個の演算子なしで成功しましたが、C では、メンバー変数と派生クラス型の両方に同じ識別子を使用できるという独自の言語機能により、この追加が必要になりました。
この違いは、コードを考慮すると明らかです。以下の例のように:
struct foo { int blah; }; struct thingy { int data; }; struct bar : public foo { thingy foo; };
このシナリオでは、bar 構造体のメンバー変数 foo と派生クラス型 foo の両方が同じ名前を共有します。このあいまいさを解決するために、スコープ解決演算子 :: が使用されます。
コンパイラーは . を検出すると、左側のオペランドがオブジェクトであると想定します。対照的に、:: は、型名、名前空間、またはグローバル名前空間を表します。この区別により、コンパイラーは次のようなコードを解釈できるようになります。
test.foo.data = 5; test.foo::blah = 10;
最初のステートメントでは、test.foo.data はオブジェクト test.foo のデータ メンバーにアクセスしていると認識されます。 2 番目のステートメントでは、test.foo::blah は派生クラス foo のメンバーにアクセスすることを示しています。
したがって、C のスコープ解決演算子は、同一性を許容することによって生じる曖昧さを解決するための精密ツールとして機能します。メンバー変数と派生クラス型の識別子。
以上がC ではスコープ解決演算子 (::) が使用されるのに、Java では使用されないのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。