[英]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
类型提供的任何内容,因此%hhx
是unsigned 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
。
一个f4
的char
值( -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.