这个主要是调试程序的时候发现的,我试图将一个小于32位的值(例如一个8位或16位的值)赋值给一个int类型的变量时,这个值通常会被扩展到一个32位的整数。这个过程叫做整数提升。被扩展的同时,符号位也会被扩展,所以会在前面填充很多1以保持数值的符号不变。因此,调试的时候发现,给char 赋值0xAD,转换为int会变成一个很大很大的值。
如果想保留原状,可以加上unsigned int再进行输出,加上unsigned以后就可以阻止符号扩展了。
这个主要是调试程序的时候发现的,我试图将一个小于32位的值(例如一个8位或16位的值)赋值给一个int类型的变量时,这个值通常会被扩展到一个32位的整数。这个过程叫做整数提升。被扩展的同时,符号位也会被扩展,所以会在前面填充很多1以保持数值的符号不变。因此,调试的时候发现,给char 赋值0xAD,转换为int会变成一个很大很大的值。
如果想保留原状,可以加上unsigned int再进行输出,加上unsigned以后就可以阻止符号扩展了。