cout을 사용하여 함수 포인터 인쇄
C에서는 cout을 사용하여 함수 포인터를 직접 인쇄하는 것이 문제가 될 수 있습니다. 대신, 인쇄하기 전에 함수 포인터를 void*로 변환하는 것이 좋습니다. 이는 다음 코드 조각에서 설명됩니다.
#include <iostream> using namespace std; int foo() {return 0;} int main() { int (*pf)(); pf = foo; cout << "cout << pf is " << pf << endl; cout << "cout << (void *)pf is " << (void *)pf << endl; printf("printf(\"%p\", pf) is %p\n", pf); return 0; }
출력:
cout << pf is 1 cout << (void *)pf is 0x100000b0c printf("%p", pf) is 0x100000b0c
위에서 볼 수 있듯이 cout은 암시적으로 함수 포인터를 bool로 변환하여 출력 1을 생성합니다. 함수의 실제 주소는 void*로 캐스팅되어야 합니다.
void* 유형의 함수 포인터는 cout을 사용하여 직접 인쇄하십시오. 이는 void*가 함수 포인터를 포함하여 모든 유형의 주소를 보유할 수 있는 일반 포인터 유형이기 때문입니다.
멤버 함수 포인터 관찰
다음을 사용하여 멤버 함수 포인터 인쇄 void*는 더 복잡한 구조로 인해 작동하지 않습니다. 그러나 C 표준에 따르면 함수 포인터의 rvalue는 bool로 변환될 수 있습니다.
위 내용은 `cout`을 사용하여 C에서 함수 포인터를 올바르게 인쇄하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!