다음 코드 조각을 고려하세요.
class Address { int i ; char b; string c; public: void showMap ( void ) ; }; void Address :: showMap ( void ) { cout << "address of int :" << &i << endl ; cout << "address of char :" << &b << endl ; cout << "address of string :" << &c << endl ; }
예상대로 출력에는 다음이 표시되어야 합니다. int, char 및 string 멤버 변수의 주소입니다. 그러나 char 변수 b의 주소는 비어 있습니다.
이 이상한 현상은 << 연산자는 &b를 주소가 아닌 C 스타일 문자열로 해석합니다. Char 포인터는 <<에 의해 null로 끝나는 문자 시퀀스로 해석됩니다. 연산자.
이 문제를 해결하고 char 변수의 주소를 표시하려면 다음 수정된 코드를 사용할 수 있습니다.
cout << "address of char :" << (void *) &b << endl;
여기서는 &b를 void *로 명시적으로 변환하는 C 스타일 캐스트입니다. 이는 << 연산자를 사용하여 문자 시퀀스가 아닌 주소로 처리합니다. 더 안전한 대안은 static_cast를 사용하는 것입니다.
cout << "address of char :" << static_cast<void *>(&b) << endl;
int, char 및 string 멤버 변수가 공개로 선언되면 출력이 약간 변경됩니다.
... int : something ... char : ... string : something_2
여기서 Something_2는 항상 Something보다 8이 적습니다.
이 차이는 다음과 같은 이유로 발생합니다. 컴파일러는 공용 멤버 변수를 채워 메모리 액세스에 최적으로 정렬합니다. 이 경우 char 변수가 8바이트로 채워져 int 변수와 string 변수 사이의 주소가 8바이트 차이가 날 수 있습니다.
위 내용은 `cout`이 `char` 멤버 변수의 주소를 올바르게 표시하지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!