서명되지 않은 문자를 사용하여 cout의 예측할 수 없는 동작 뒤에 숨겨진 미스터리 공개
프로그래밍에서 예상치 못한 출력은 종종 좌절과 혼란을 초래할 수 있습니다. 다음 코드를 고려하십시오.
#include<iostream> #include<stdio.h> using namespace std; int main() { unsigned char a; a = 1; printf("%d", a); cout << a; }
이 코드는 부호 없는 char 변수 'a'에 저장된 값인 1을 인쇄하도록 설계되었습니다. 그러나 실행되면 "1"이 인쇄되고 그 뒤에 일부 내용이 인쇄됩니다. 임의의 문자. 이 시나리오에서 cout이 printf와 다르게 동작하는 이유는 무엇입니까?
답은 unsigned char의 특성에 있습니다. 0~31의 값이 할당된 ASCII 문자는 인쇄할 수 없는 것으로 간주됩니다. 값 1에 할당된 문자는 인쇄할 수 없는 문자이므로 cout은 어쨌든 인쇄를 시도합니다. 문자가 인쇄 가능한지 확인하려면 std::isprint 함수를 사용할 수 있습니다.
std::cout << std::isprint(a) << std::endl;
이 명령문은 0(false)을 인쇄하여 해당 문자를 인쇄할 수 없음을 나타냅니다.
이 문제를 해결하고 cout이 a의 값을 1로 인쇄하도록 강제하려면 이를 unsigned로 캐스팅할 수 있습니다. 정수:
cout << static_cast<unsigned>(a) << std::endl;
이 캐스트는 인쇄할 수 없는 문자를 해당하는 부호 없는 정수 값으로 변환하여 cout이 1을 올바르게 인쇄하도록 합니다.
위 내용은 `printf`는 처리하지 않지만 `unsigned char`을 처리할 때 `cout`이 예기치 않은 문자를 인쇄하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!