Char 포인터의 Cout 해석
다음을 결정하기 위해 특정 변환 지정자(%u 또는 %s)를 제공하는 printf()와는 다릅니다. char 포인터가 가리키는 주소 또는 전체 문자열을 인쇄하려면 cout에서는 이러한 구별을 위해 명시적인 접근 방식이 필요합니다.
예제 문제:
다음 코드 조각을 고려하세요.
<code class="cpp">int main() { char ch = 'a'; char *cptr = &ch; cout << cptr << endl; return 0; }
이 예에서 기본 GNU 컴파일러를 사용하면 cout은 char 포인터를 C 스타일 문자열로 해석하고 cptr이 가리키는 문자를 인쇄하려고 시도합니다. 그러나 ch의 주소를 대신 인쇄하려는 경우에는 다른 접근 방식이 필요합니다.
해결책:
cout과 함께 cptr을 사용하여 ch의 주소를 인쇄하려면 , 명시적인 유형 캐스팅이 필요합니다. 이는 static_cast<> 아래에 설명된 것처럼 연산자:
<code class="cpp">cout << static_cast<void *>(cptr) << endl;</code>
cptr을 void *로 명시적으로 캐스팅함으로써 오버로드 해결은 void 포인터를 인수로 사용하는 적절한 ostream& 연산자를 선택합니다. 그러면 ch의 주소가 올바르게 인쇄됩니다.
위 내용은 `cout`을 사용하여 Char 포인터로 주소를 인쇄하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!