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