문자 포인터에 대한 스트림 연산자 오버로딩 이해
printf()를 사용하여 문자 포인터를 인쇄할 때 변환 지정자는 주소 또는 주소는 %u, 문자열은 %s와 같이 문자열이 인쇄됩니다. 그러나 C 스트림과 cout의 경우 출력할 항목을 어떻게 결정합니까?
다음 코드를 고려하세요.
<code class="cpp">char ch = 'a'; char *cptr = &ch; cout << cptr << endl;
이 예에서 cout은 cptr을 문자열로 해석하려고 시도합니다. cout을 사용하여 ch의 주소를 인쇄하려면 이 모호성을 해결하기 위해 변환을 적용해야 합니다.
해결책: Void 포인터로 캐스팅
cout을 사용하는 주소는 유형 캐스팅을 통해 이루어집니다. 올바른 접근 방식은 다음과 같습니다.
<code class="cpp">cout << static_cast<void *>(cptr) << endl;</code>
cptr을 void *로 캐스팅하면 cout이 void 포인터(ostream& 연산자<< (ostream& o, const void *p)를 사용하는 적절한 오버로드를 실행하도록 강제합니다. )). 이렇게 하면 주소가 의도한 대로 인쇄됩니다.
위 내용은 문자 포인터를 전달할 때 'cout'은 주소를 인쇄할지 아니면 문자열을 인쇄할지 어떻게 결정합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!