f의 궁금한 사례; 출력에서 항상 1을 인쇄하는 이유는 무엇입니까?
괄호(f;) 없이 함수를 호출하고 그 결과를 std::cout으로 인쇄하면 일관되게 숫자 1이 생성되는 특이한 동작에 직면하면 의문이 생길 수 있습니다. 처음에는 코드가 함수 포인터를 인쇄할 것으로 예상할 수 있지만 관찰 결과는 그렇지 않은 것으로 나타납니다.
아래 코드를 자세히 살펴보면
<code class="cpp">#include <iostream> using namespace std; void pr() { cout << "sth"; } int main() { pr; cout << pr; // output: 1 cout << *pr; // output: 1 cout << ≺ // output: 1 }
pr; 기술적으로 pr() 함수를 호출하지 않습니다. 대신 함수 포인터가 cout에 전달됩니다. 이 프로세스 중에 함수 포인터가 bool로 변환되면 0이 아닌 값이 true로 평가되는 논리 표현식과 유사하게 동작합니다. 이는 인쇄되면 1로 변환됩니다.
게다가 C 11 이전 표준에서는 함수 포인터 스트리밍을 허용하는 오버로드가 없습니다. 이로 인해 std::cout을 사용하여 함수 포인터의 형식을 직접 지정하고 인쇄하는 것이 어려워집니다. 그러나 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) << ")"; }
이 오버로드를 사용하면 cout << pr은 이제 다음을 인쇄합니다.
<code class="text">(func_ptr=<address of pr>)(num_args=0)</code>
이 사용자 정의 오버로드는 다양한 인자의 인쇄 함수 포인터를 보여줍니다. 함수 포인터 문제를 완화하지만 원하는 오버로드를 지정하는 것이 필수적인 오버로드된 함수 또는 함수 템플릿과 관련된 시나리오를 완전히 해결하지는 않습니다.
위 내용은 `std::cout은 왜 하는가?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!