byte数据类型确实是一个字节8位,上面所说的32位是指0xa2这个常量占32位,java中整数常量默认为int,(byte)0x32是将这个int型数据强制转化为byte,从而只算计算0xa2的第24位到第32位的数。至于高位补一的原因,是因为0xa2强制转化为8位后表示负数,需要让原始的32位数也表示为负数,负数补码前面补1就相当于原码补0。