수수께끼의 멤버 함수 포인터 호출 공개
객체 지향 프로그래밍의 세계에서 멤버 함수 포인터는 클래스를 조작하는 데 중요한 역할을 합니다. 회원. 그러나 포인터를 통해 멤버 함수를 호출하는 것은 복잡한 작업이 될 수 있습니다. 다음 코드 조각을 고려해보세요.
class cat { public: void walk() { printf("cat is walking \n"); } }; int main(){ cat bigCat; void (cat::*pcat)(); pcat = &cat::walk; bigCat.*pcat(); }
이 코드를 컴파일하려고 하면 오류가 발생합니다. 흥미로운 질문이 남아 있습니다. 겉보기에 무해해 보이는 bigCat.*pcat() 문이 왜 컴파일에 실패합니까?
문제 해독
답은 연산자의 우선 순위에 있습니다. . 이 코드 조각에서 () 표현식은 .* 멤버에 대한 포인터 바인딩 연산자보다 우선순위가 높습니다. 결과적으로 컴파일러는 표현식을 의도한 동작이 아닌 (bigCat.*)pcat()으로 해석합니다.
난제 해결
이 문제를 해결하려면, 작업의 우선순위를 명시적으로 지정해야 합니다. bigCat.*pcat() 표현식 주위에 괄호를 추가하여 포인터-멤버 바인딩이 먼저 발생하도록 합니다.
(bigCat.*pcat)();
결론
괄호를 올바르게 배치하면 이제 코드가 오류 없이 컴파일되고 실행됩니다. 이는 코드를 올바르게 해석하려면 연산자 우선 순위를 이해하는 것이 가장 중요하다는 점을 상기시켜 줍니다.
위 내용은 멤버 함수 포인터를 호출할 때 `bigCat.*pcat()`이 컴파일되지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!