호출 없이 함수 포인터 인쇄
괄호 없이 함수를 인쇄하려고 할 때(예: f() 대신 f로), 항상 값 1을 인쇄하는 등 예상치 못한 결과가 발생할 수 있습니다. 이 역설적인 동작은 관련된 기본 메커니즘에서 비롯됩니다.
제공된 코드에서 cout << 홍보; 실제로 pr 함수를 호출하지 않습니다. 대신, 함수 포인터 pr을 cout에 전달합니다. C는 암시적으로 이 포인터를 bool 값으로 해석하며, null이 아닌 포인터는 true로 평가되어 1로 인쇄됩니다.
함수 포인터 자체를 인쇄하려면 명시적으로 void* 포인터로 캐스팅해야 합니다. . 이는 cout <<와 같은 표현식을 사용하여 달성할 수 있습니다. (void*)pr.
C 11과 함수 포인터 오버로딩
C 11의 출현과 함께 함수 포인터를 인쇄하는 더 편리한 방법이 등장했습니다. << 함수 포인터에 대한 연산자를 사용하면 더 많은 정보를 출력할 수 있습니다. 예를 들어, 함수의 주소와 개수(인수 수)를 인쇄하는 오버로드를 정의할 수 있습니다.
<code class="cpp">template <class RType, class ... ArgTypes> std::ostream & operator<<(std::ostream & s, RType(*func)(ArgTypes...)) { return s << "(func_ptr=" << (void*)func << ")(num_args=" << sizeof...(ArgTypes) << ")"; }
이 오버로드는 (func_ptr=
) (num_args=<) 형식으로 출력을 인쇄합니다. ;arity>).위 내용은 호출하지 않고 C에서 함수 포인터를 인쇄하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!