我的補0判斷哪里出了問題呢?
for(int i=0;i<bytes;i++){
? ?
? ? if(buf[i]<=0xf){
? ? System.out.print("0");
? ? }
? ? System.out.print(Integer.toHexString(buf[i] & 0xff)+" ");
? ? if(j++%10==0){
? ? System.out.println();
? ? }
? ? }
輸出結果是這樣的
0f7 0bc 0fc 0d2 0d4 0cd 0e2 0b5 0c4 0c6?
0e4 0cb 0fb 0c1 0d0 0b6 0bc 0b2 0bb 0b4?
0ab 0b5 0dd 0d2 0c0 0c0 0b5 0d3 0da 0d6?
0f7 0bc 0fc 0c1 0d0 0a3 0ac 0d4 0f2 0c2?
0fa 0d7 0e3 0b5 0da 0c8 0fd 0b7 0b6 0ca?
0bd 0a1 0a3
2020-05-26
補0判斷不嚴謹,如果有中文的話會出現負值
if (buf[j]<=0xf&&buf[j]>=0) {
System.out.print(0);
}
2020-03-17
你把上面的判斷添加buf[i]<=0xf;改成(buf[i]& 0xff)<=0xf
2019-11-05
你的補0判斷沒有問題,只不過是因為你的讀取文件中,包含了中文,而中文在字節數組中保存的數值是負值,
?if(buf[i]<=0xf){
? ? System.out.print("0");
? ? }
所以但凡是中文 都會經由此補上0,而且看你輸出的全是3位補0,應該是全文字內容,你再加入一點字母數字,就會發現有3位和兩位并存的現象