繁体   English   中英

C / C ++以十六进制打印字节,获取奇怪的十六进制值

[英]C/C++ Printing bytes in hex, getting weird hex values

我正在使用以下内容从十六进制数组中打印出数字:

char buff[1000];

// Populate array....

int i;
for(i = 0; i < 1000; ++i)
{
    printf("[%d] %02x\n", i,buff[i]);
}

但是我有时会打印出奇怪的值:

byte[280] 00     
byte[281] 00     
byte[282] 0a     
byte[283] fffffff4         // Why is this a different length?
byte[284] 4e      
byte[285] 66      
byte[286] 0a   

为什么打印“ fffffff4”?

使用%02hhx作为格式字符串。

CppReference中%02x接受unsigned int 当您将参数传递给可变参数函数 printf()buff[i]将自动转换为int 然后,格式说明符%02x使printf()将该值解释为int ,因此可能的负值(char)-1(char)-1被解释并打印为(int)-1 ,这就是您所观察到的原因。

也可以推断出您的平台已签名char类型和32位int类型。

长度修饰符hh将告诉printf()解释以char类型提供的任何内容,因此%hhxunsigned char的正确格式说明符。

或者,您可以在打印之前将数据转换为unsigned char 喜欢

printf("[%d] %02x\n", i, (unsigned char)buff[i]);

由于int可以(几乎)始终包含unsigned char值,因此这也可以防止出现负值的时间过长。


请参见以下示例:

#include <stdio.h>

int main(){
    signed char a = +1, b = -1;
    printf("%02x %02x %02hhx %02hhx\n", a, b, a, b);
    return 0;
}

上面程序的输出是:

01 ffffffff 01 ff

您的平台显然已签署了char char不带符号的平台上,输出将为f4

调用可变参数函数时,任何小于int整数参数都将提升为int

一个f4char值( -12为一个有signed char )已设置了符号位,因此在您的情况下,转换为int时将变为fffffff4 (仍为-12但现在作为一个有signed int )。

%x02使printf将参数视为unsigned int ,并将使用至少 2个十六进制数字进行打印。 输出的两位数不合适,因此使用了所需的位数。

因此输出fffffff4

要解决此问题,请声明数组unsigned char buff[1000];否则,请执行以下操作unsigned char buff[1000]; 或强制转换参数:

    printf("[%d] %02x\n", i, (unsigned char)buff[i]);

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM