int8_t a = -1; uint32_t b = a; b = ?
这要用到整型转换规则, C Programming Language(K & R) (A.6.2)上这样解释:ui
将任何整数转换为某种指定的无符号数类型数的方法是:以该无符号数类型可以表示的最大值加1为模,找出与此整数同余的最小的非负值。
在对二的补码表示中,若是该无符号类型的位模式较窄,这就至关于左截取;若是该符号类型的位模式较宽,这就至关于对带符号的值进行符号扩展和对无符号的值进行0填充。code
将任何整数转换为带符号类型时,若是它能够在新的类型中表示出来,则其值保持不变,不然它的值同具体的实现有关。变量
其中以该无符号数类型可以表示的最大值加1为模,找出与此整数同余的最小的非负值
,我以为太拗口,下面那段才比较好理解在对二的补码表示中,若是该无符号类型的位模式较窄,这就至关于左截取;若是该符号类型的位模式较宽,这就至关于对带符号的值进行符号扩展和对无符号的值进行0填充。
扩展
好比把 0x1234 放到一个 uint8_t 类型变量 x 中,那么高 8 位就被截掉,低 8 位被放到变量中,最终 x 的值为 0x34。
好比把 -1 放到 x 中,由于 -1 的二进制码是 0xFFFFFFFF,那么 x 的值就等于 0xFF。二进制