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 개체의 데이터 멤버에 액세스하는 것으로 인식됩니다. 두 번째 명령문에서 test.foo::blah는 파생 클래스 foo의 blah 멤버에 액세스하는 것을 나타냅니다.
따라서 C의 범위 확인 연산자는 동일 허용으로 인해 생성된 모호성을 해결하기 위한 정밀 도구 역할을 합니다. 멤버 변수 및 파생 클래스 유형에 대한 식별자입니다.
위 내용은 C에서는 범위 확인 연산자(::)를 사용하는 반면 Java에서는 사용하지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!