C에서 정적 및 비정적 함수 오버로드
C에서는 정적 함수를 비정적 함수로 오버로드하는 것이 불가능합니다. C 표준의 명시적인 금지로 인해 함수가 작동합니다. 이는 ISO 14882:2003 C 표준 13.1/2에 명시되어 있으며, 동일한 이름과 매개변수 유형을 가진 멤버 함수 선언 중 하나라도 정적 멤버 함수 선언인 경우 오버로드될 수 없음을 지정합니다.
모호함 with Static Function Invocation
또한 C에서는 인스턴스에 대한 정적 함수 호출이 가능합니다. ISO 14882:2003 C 표준 9.4/2에 따라 클래스 X의 정적 멤버 s는 정규 ID 표현식 X::s를 사용하여 참조할 수 있습니다. 이는 클래스 멤버 액세스 구문을 사용하여 클래스 멤버 액세스 구문을 사용할 필요가 없음을 의미합니다. 정적 멤버입니다.
이로 인해 인스턴스에서 정적 함수를 호출할 때 모호함이 발생합니다. 다음 예를 고려하십시오.
<code class="cpp">class Foo { public: string bla; Foo() { bla = "nonstatic"; } void print() { cout << bla << endl; } static void print() { cout << "static" << endl; } };</code>
이 예에서는 f.print() 호출이 모호합니다. 왜냐하면 정적 또는 비정적 print() 함수를 호출할지 여부가 불분명하기 때문입니다. C 표준에서는 이 구문을 통해 정적 멤버 함수 호출을 허용하지만 동일한 이름을 가진 비정적 함수가 있으면 모호성이 발생합니다.
정적 함수 호출 확인
PHP와 달리 C에서는 함수가 정적으로 호출되는지 여부를 직접 확인할 수 있는 방법을 제공하지 않습니다. 함수가 호출된 개체를 가리키는 this 키워드는 항상 개체를 가리키므로 함수가 정적으로 호출되는지 여부를 확인할 수 없습니다.
위 내용은 C에서 정적 및 비정적 함수가 오버로드될 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!