>백엔드 개발 >C++ >`printf`는 처리하지 않지만 `unsigned char`을 처리할 때 `cout`이 예기치 않은 문자를 인쇄하는 이유는 무엇입니까?

`printf`는 처리하지 않지만 `unsigned char`을 처리할 때 `cout`이 예기치 않은 문자를 인쇄하는 이유는 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-04 10:44:10507검색

Why Does `cout` Print Unexpected Characters When Handling `unsigned char` While `printf` Doesn't?

서명되지 않은 문자를 사용하여 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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