課程
/后端開發(fā)
/Java
/文件傳輸基礎(chǔ)——Java IO流
如題如題如題
2016-10-30
源自:文件傳輸基礎(chǔ)——Java IO流 4-2
正在回答
簡(jiǎn)單點(diǎn)說,原來開辟空間之后輸入的buf是Byte型,只有8位。現(xiàn)在要用Integer.toHexString把int型轉(zhuǎn)化成字符型,這個(gè)函數(shù)括號(hào)里輸入的一定要是int型也就是32位;為了不發(fā)生錯(cuò)誤,就先用位與&把Byte型(只有8位)前面的24位全都變成0(比如:byte數(shù)據(jù)1011 1011&1111 1111 1111 1111....,按位運(yùn)算,高位不足補(bǔ)0,1&1=1,1&0=0,0&0=0)。打個(gè)比方就是:8個(gè)乒乓球(byte數(shù)據(jù))放到長(zhǎng)度為32的筒狀盒子(Integer)里,為了讓這8個(gè)球不亂晃并且剛好貼近開口方便拿(可以正確讀?。?,就把底部24個(gè)長(zhǎng)度用廢報(bào)紙(與0xff得到的高24位)塞上。有或者沒有&0xff看具體用什么數(shù)據(jù)類型,不是都要加的,“與ff”是數(shù)據(jù)存儲(chǔ)時(shí)把短數(shù)據(jù)變成長(zhǎng)數(shù)據(jù)的常用做法。
源碼里已經(jīng)進(jìn)行了&0xff操作
你肯定之前的沒看懂,老實(shí)說read讀取低8位,其余為補(bǔ)0,用Integer.toHexString()方法就不會(huì)輸出前面的0;相反去過在不知道其位的情況下,需要&0xff手動(dòng)將其余位清零。具體的你需要知道在計(jì)算機(jī)中任何數(shù)字都以反碼存放,去了解相關(guān)知識(shí)吧。
方法printHex是無符號(hào)讀取,所有的字節(jié)前面都是加24個(gè)零,這樣就不會(huì)出現(xiàn)
出0ffffffa之類的了
貌似那里放的是byte還是什么類型。一個(gè)byte就是8位(8bit),一個(gè)8位的長(zhǎng)度所以就能放完。但是int類型占用的是4個(gè)字節(jié),每個(gè)字節(jié)是8位,一共32位,所以要放4次,每次放8位。
因?yàn)榈谝粋€(gè)里面的放置的都是用8位就能表示完的數(shù)或者什么的,沒必要這樣做了。建議去看看微機(jī)原理,進(jìn)制和數(shù)據(jù)表示。
舉報(bào)
為您介紹IO流的使用,以及對(duì)象的序列化和反序列化的內(nèi)容
1 回答為什么還要多出一個(gè)字符流這種方法
1 回答在輸出byte[]數(shù)組的buf[i]時(shí),會(huì)輸出一個(gè)int型的4字節(jié)的數(shù)
3 回答老師的System.out.print(Integer.toHexString(buf[i]&0xff)+" ");句中為什么要加0xff?
2 回答foreach取buf里面的每一個(gè)byte以后,為什么還要&0xff,一個(gè)byte不是已經(jīng)8bit了嗎
1 回答這三種方法定義的String類型有什么不同,b是一個(gè)字符數(shù)組
Copyright ? 2025 imooc.com All Rights Reserved | 京ICP備12003892號(hào)-11 京公網(wǎng)安備11010802030151號(hào)
購(gòu)課補(bǔ)貼聯(lián)系客服咨詢優(yōu)惠詳情
慕課網(wǎng)APP您的移動(dòng)學(xué)習(xí)伙伴
掃描二維碼關(guān)注慕課網(wǎng)微信公眾號(hào)
2017-04-06
簡(jiǎn)單點(diǎn)說,原來開辟空間之后輸入的buf是Byte型,只有8位。現(xiàn)在要用Integer.toHexString把int型轉(zhuǎn)化成字符型,這個(gè)函數(shù)括號(hào)里輸入的一定要是int型也就是32位;為了不發(fā)生錯(cuò)誤,就先用位與&把Byte型(只有8位)前面的24位全都變成0(比如:byte數(shù)據(jù)1011 1011&1111 1111 1111 1111....,按位運(yùn)算,高位不足補(bǔ)0,1&1=1,1&0=0,0&0=0)。打個(gè)比方就是:8個(gè)乒乓球(byte數(shù)據(jù))放到長(zhǎng)度為32的筒狀盒子(Integer)里,為了讓這8個(gè)球不亂晃并且剛好貼近開口方便拿(可以正確讀?。?,就把底部24個(gè)長(zhǎng)度用廢報(bào)紙(與0xff得到的高24位)塞上。有或者沒有&0xff看具體用什么數(shù)據(jù)類型,不是都要加的,“與ff”是數(shù)據(jù)存儲(chǔ)時(shí)把短數(shù)據(jù)變成長(zhǎng)數(shù)據(jù)的常用做法。
2017-04-16
源碼里已經(jīng)進(jìn)行了&0xff操作
2017-02-12
你肯定之前的沒看懂,老實(shí)說read讀取低8位,其余為補(bǔ)0,用Integer.toHexString()方法就不會(huì)輸出前面的0;相反去過在不知道其位的情況下,需要&0xff手動(dòng)將其余位清零。具體的你需要知道在計(jì)算機(jī)中任何數(shù)字都以反碼存放,去了解相關(guān)知識(shí)吧。
2016-11-01
方法printHex是無符號(hào)讀取,所有的字節(jié)前面都是加24個(gè)零,這樣就不會(huì)出現(xiàn)
出0ffffffa之類的了
2016-10-30
貌似那里放的是byte還是什么類型。一個(gè)byte就是8位(8bit),一個(gè)8位的長(zhǎng)度所以就能放完。但是int類型占用的是4個(gè)字節(jié),每個(gè)字節(jié)是8位,一共32位,所以要放4次,每次放8位。
2016-10-30
因?yàn)榈谝粋€(gè)里面的放置的都是用8位就能表示完的數(shù)或者什么的,沒必要這樣做了。建議去看看微機(jī)原理,進(jìn)制和數(shù)據(jù)表示。