為什么要取低八位
for(byte?b:buf){ ????System.out.println(integer.toHexString(b&0xff)+""); }
b本來就是byte類的數(shù)組,只有一個字節(jié) 8位,為什么還要&0xff呢?
for(byte?b:buf){ ????System.out.println(integer.toHexString(b&0xff)+""); }
b本來就是byte類的數(shù)組,只有一個字節(jié) 8位,為什么還要&0xff呢?
2017-03-07
舉報
2017-03-07
因為十六進制數(shù)總共有4個字節(jié)的符號,我們?yōu)榱嗣烙^,不要顯示多余的符號而取有意義的數(shù)的時候我們就要跟我們獲得的值的位數(shù)相&,這樣前面的ffff就有消失,你可以去掉&0xff試試。
2017-03-10
找到答案了,我來自問自答。我是在其他問題中找到的,問題的地址我忘記保存了。
在32位的電腦中數(shù)字都是以32格式存放的,如果是要求一個byte(8位)類型的數(shù)字,對于int這種32位的整形,高24位具有隨機性(從所有的數(shù)字形式來看,前面的24位取值并不確定,我把它視為具有一定的隨機性,比如int型的整數(shù),高24位的取值都是不確定的。),低8位才是實際的數(shù)據(jù)。
Java.lang.Integer.toHexString() 方法的參數(shù)是int(32位)類型,如果輸入一個byte(8位)類型的數(shù)字,這個方法會把這個數(shù)字的高24為也看作有效位,這就必然導致錯誤,使用& 0XFF操作,可以把高24位置0以避免這樣錯誤的生。
引自:http://blog.csdn.net/wangyang1354/article/details/52290461