1.Java中涉及byte、short和char类型的运算操作首先会把这些值转换为int类型,然后对int类型值进行运算,最后得到int类型的结果。因此,如果把两个byte类型值相加,最后会得到一个int类型的结果。如果需要得到byte类型结果,必须将这个int类型的结果显式转换为byte类型。
2.负数向右移位:如 -2>>3
步骤:注意java中int是4个字节,32位太长,为了方便解说,当它只有8位。不会影响结果。
a.得到-2的原码,即:10000010 (最高位为符号位,正数为0,负数为1)
b.由于计算机中负数都是按补码形式进行存储运算的,所以先要求补码:
1.原码取反得到反码: 11111101 (注意,符号位不用取反)
2.反码+1得到补码: 11111110
c.得到补码后,然后运算:为了看清楚,我们分三次进行
1.先向右移动1位,在最高位补符号位(因为是负数,所以最低位的0移出去,最高位补1,如果是整数右移,则最高位补0),得到结果:11111111
2.和上面一样,再右移1位,结果为 11111111 (如果按int 32为,则不会全是1,但是不影响结果)
3.再右移移位,得到结果: 11111111
d.补码运算完成后,然后要还原成原码。首先将结果减1,得到结果的反码: 11111110
e.然后将结果的反码取反得到原码,为:10000001 (即-1)
f.所以 -2>>3 == -1。