>  기사  >  백엔드 개발  >  함수 포인터가 괄호 없이 사용될 때 \"cout\"이 \"1\"을 인쇄하는 이유는 무엇입니까?

함수 포인터가 괄호 없이 사용될 때 \"cout\"이 \"1\"을 인쇄하는 이유는 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-10-26 09:33:301004검색

Why Does

왜 "함수를 호출하지 않고 계산합니까(f()가 아니라 f;). 항상 1을 인쇄합니까?"

여기서 코드에서는 괄호를 사용하지 않고 pr이라는 함수를 "호출"하려고 시도합니다. 그러나 이것은 실제로 함수를 호출하는 것이 아닙니다. 대신, 함수 포인터를 cout 함수에 전달합니다. 함수 포인터가 암시적으로 bool 값으로 변환되면 true로 평가됩니다. true는 C의 1과 동일하므로 출력은 항상 1입니다.

명확하게 설명하자면 제공된 코드의 다음 줄은 pr 함수를 호출하지 않습니다.

<code class="cpp">pr;
cout << pr; // output: 1
cout << *pr; // output: 1  (dereferencing the function pointer, which is still true)
cout << &pr; // output: 1 (address of the function, which is a non-zero value)</code>

실제로 호출하려면 pr 함수를 사용하려면 pr()과 같은 괄호를 사용해야 합니다.

이 동작은 함수 포인터가 암시적으로 bool로 변환될 수 있다는 사실에서 비롯됩니다. C 11에서는 연산자<< 함수 포인터가 더 유익한 출력을 제공합니다. 그러나 원하는 오버로드를 명시적으로 지정하지 않으면(보통 캐스트를 통해) 오버로드된 함수나 함수 템플릿에 대해서는 여전히 작동하지 않습니다.

위 내용은 함수 포인터가 괄호 없이 사용될 때 \"cout\"이 \"1\"을 인쇄하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.