>백엔드 개발 >C++ >단일 문자를 16진수로 인쇄할 때 `printf`가 예기치 않은 결과를 생성하는 이유는 무엇입니까?

단일 문자를 16진수로 인쇄할 때 `printf`가 예기치 않은 결과를 생성하는 이유는 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-08 09:31:17388검색

Why Does `printf` Produce Unexpected Results When Printing Single Characters as Hex?

문자 16진 인쇄로 printf의 흥미로운 동작 탐색

프로그래밍 영역에서 단일 바이트를 인쇄하는 상황에 직면할 수 있습니다. printf를 사용하는 16진수 형식은 예상치 못한 결과를 낳습니다. 문자 벡터를 픽셀 데이터로 사용할 때 흥미로운 사례가 발생합니다. "%1x" 수정자를 사용하여 단일 문자를 인쇄하려고 시도하면 종종 난처한 결과가 발생합니다.

The Mystery Unraveled

수수께끼는 유형 승격 동작에 나타납니다. by printf. 문자(char)를 varargs 함수로 printf에 전달하면 일반적으로 정수(int)로 승격됩니다. 그러나 "%x" 수정자는 부호 없는 정수(unsigned int)를 입력으로 예상합니다. 이러한 부조화는 정의되지 않은 동작으로 이어집니다.

이를 수정하고 예측 가능한 결과를 보장하려면 문자를 unsigned int로 명시적으로 캐스팅하는 것이 필수적입니다. 다음 수정 사항은 솔루션을 보여줍니다.

printf(" 0x%1x ", (unsigned)pixel_data[0] );

16진수 표현에는 항상 최소한 한 자리가 필요하므로 이 맥락에서 필드 너비가 1이면 유용성이 제한된다는 점에 주목할 가치가 있습니다.

서명된 데이터와 서명되지 않은 데이터에 대한 의미

char가 지정된 플랫폼에서 부호 있는 음수 문자 값은 승격 시 부호 없는 큰 정수 값으로 변환됩니다. 이를 방지하려면 픽셀 데이터에 unsigned char을 사용하거나 unsigned int 캐스팅 또는 마스크 기반 0 확장을 사용하는 것이 좋습니다. 대체 접근 방식의 예는 다음과 같습니다.

printf(" 0x%x ", (unsigned)(unsigned char)pixel_data[0] );

printf(" 0x%x ", (unsigned)pixel_data[0] & 0xffU );

이러한 솔루션은 원하는 바이트 값을 부호 없는 정수로 변환하여 일관되고 예상되는 출력을 제공합니다.

위 내용은 단일 문자를 16진수로 인쇄할 때 `printf`가 예기치 않은 결과를 생성하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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