java 负数存储结构_负数在java中的存储和读取过程 | 学步园
問題描述:
將-5存儲在文本文件中,再讀取出來顯示到控制臺;
預(yù)備知識:
1.在java中使用補(bǔ)碼處理數(shù)字,而且byte(8)的數(shù)字在擴(kuò)展成int(32)類型的時(shí)候,正數(shù)填充0,負(fù)數(shù)填充1;
2.負(fù)數(shù)的轉(zhuǎn)變過程
,
正數(shù)的原碼,反碼,補(bǔ)碼,都一樣;
解決步驟:
1. ?-5(5)在byte類型中的表示是1000 0011(0000 0011) 當(dāng)它擴(kuò)展成int的時(shí)候會(huì)變成 11111111 11111111 11111111 11111011(00000000 00000000 00000000 ?00000011);
2.
byte binaryInt = -5;
Path path = Paths.get("..");
try {
OutputStream out = new BufferedOutputStream(Files.newOutputStream(path,
CREATE));
out.write(binaryInt);
out.flush();
out.close();
BufferedInputStream input = new BufferedInputStream(Files.newInputStream(path));
int i= input.read();
input.close();
System.out.println(i);
} catch (IOException ex) {
}
輸出為 251
3.原因
第一步是看寫入操作
jdk BufferedOutputStream write()源碼
public synchronized void write(int b) throws IOException {
if (count >= buf.length) {
flushBuffer();
}
buf[count++] = (byte)b;
}
在寫入操作的時(shí)候只是把11111111 11111111 11111111 11111011的后8位寫入了文件中,這也就解釋了文件中為什么是0xFB
的原因了;
然后是讀取操作
jdk InputStream read() 源碼
public synchronized int read() throws IOException {
if (pos >= count) {
fill();
if (pos >= count)
return -1;
}
return getBufIfOpen()[pos++] & 0xff;
}
java中位運(yùn)算會(huì)先將參與運(yùn)算的數(shù)據(jù)類型轉(zhuǎn)換成int,
證明了這一點(diǎn);所以getBufIfOpen()[pos++]擴(kuò)展成int數(shù)據(jù)類型時(shí)候是11111111 11111111 11111111 11111011,getBufIfOpen()[pos++] & 0xff就變成了11111111 11111111 11111111 11111011&00000000 00000000 00000000 11111111最后是251;
4.解決辦法
int i= input.read()-256;就可以得到原值了;
總結(jié)
以上是生活随笔為你收集整理的java 负数存储结构_负数在java中的存储和读取过程 | 学步园的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 弹出窗口总结
- 下一篇: docker版本Mysql安装