>백엔드 개발 >C++ >`std::cout은 왜 하는가?

`std::cout은 왜 하는가?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-10-28 02:37:311075검색

Why does `std::cout

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 << &pr; // 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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