當我們要從網絡下載資源時,使用類似如下方法來獲取InputStream實例:
URLConnection connection = new URL("http://www.XXXX.XXX").openConnection(); InputStream inputStream = connection.getInputStream();
但是這個InputStream實例與我們讀取文件的InputStream實例有一些不同之處。
先說一下使用InputStream讀取文件
InputStream inputStream = new FileInputStream(new File("XXX"));
我們可以通過inputStream.available()來獲取文件的字節數
使用inputStream.read(byte[] b, int off, int len)來嘗試讀取len個字節到字節數組b中,如果輸入流中的字節大於len,則讀取len個數組,如果輸入流中的字節數小於len,則讀取剩余的字節個數,並最終返回讀取的字節數,讀取到文件結尾的時候會返回-1。
但是對於connection.getInputStream()方法獲取的輸入流,則以上兩個方法就不適用了:
available()方法獲取到的字節數會與輸入流中的總字節數相差很大,如果要獲取網絡資源的具體字節數,就要使用connection.getContentLength()方法獲取。
而inputStream.read(byte[] b, int off, int len)方法,在字節數組b長度和len很大的時候,會出現讀取不全的情況,即輸入流中的字節數大於len個,但是讀取出來的字節數仍小於len個的情況。所以這種情況就必須使用while循環讀取,通過返回值來確定讀取的字節數(讀取文件的時候最好也這么做)
while ((length = inputStream.read(data, 0, data.length)) != -1) { XXXX }