while((bytes = in.read(buf,0,buf.length))!=-1)這里有疑問(wèn)
while((bytes = in.read(buf,0,buf.length))!=-1)
搞不明白,假如文件100字節(jié),數(shù)組buf容量80字節(jié),第一次讀完的時(shí)候bytes等于80,然后執(zhí)行完后邊的代碼,程序如何回到while循壞呢?
不是已經(jīng)這樣了嗎 bytes=80!=-1,不應(yīng)該是一個(gè)死循環(huán)嗎?有些理解不了這個(gè)
而且就算我現(xiàn)在當(dāng)做能明白這個(gè)循環(huán)為什么能進(jìn)行了,可buf數(shù)組在第一次循環(huán)的時(shí)候已經(jīng)被填滿(mǎn)了呀,第二次去循環(huán)的時(shí)候,是把剩下的20字節(jié)覆蓋進(jìn)去嗎?而且in.read(buf,0,buf.length))這里第二個(gè)參數(shù)是“0”,也沒(méi)有看出來(lái)任何地方對(duì)這個(gè)參數(shù)有修改,程序怎么知道應(yīng)該是從81位開(kāi)始讀呢?
2020-07-20
讀入緩沖區(qū)的總字節(jié)數(shù),如果沒(méi)有更多的數(shù)據(jù),因?yàn)槲募慕Y(jié)尾已經(jīng)到達(dá),
-1
。?剛查了下API文檔,一樓的回復(fù)太給力了,讓我也懂了
2019-04-02
read()方法返回的是下一個(gè)字節(jié)
2018-07-21
in.read(buf,0,buf.length),這個(gè)方法返回的是它讀取到的字節(jié)個(gè)數(shù)!
正如你假設(shè)的,文件100字節(jié),buf容量80字節(jié):
第一次讀取的時(shí)候是返回80;
第二次進(jìn)入while的時(shí)候,文件讀取的字節(jié)是從第81個(gè)字節(jié)開(kāi)始(讀取的時(shí)候文件有個(gè)指針一邊讀一邊移動(dòng)的,前面老師講過(guò)),就是說(shuō)文件還剩下20個(gè)字節(jié)可讀,所以這時(shí)候返回的字節(jié)是20;
第三次進(jìn)入while的時(shí)候,文件已經(jīng)沒(méi)有內(nèi)容可讀了,所以返回的是-1;
這時(shí)候就跳出了while!
純手打!望采納!