java獲取文件大小的幾種方法
目前Java獲取文件大小的方法有兩種:
1、通過(guò)file的length()方法獲??;
2、通過(guò)流式方法獲??;
通過(guò)流式方法又有兩種,分別是舊的java.io.*中FileInputStream的available()方法和新的java..nio.*中的FileChannel
下面依次介紹這幾種方法:
首先選擇一個(gè)文件并查看這個(gè)文件在windows中顯示的大小,為了測(cè)試準(zhǔn)確性,我這里選取了一個(gè)大文件(超過(guò)2GB)
查看這個(gè)文件在windows中顯示的大?。?/p>
使用在線轉(zhuǎn)換工具將其轉(zhuǎn)換成字節(jié):
可以看出這個(gè)文件的實(shí)際大小是3265574912Byte,下面通過(guò)代碼來(lái)獲取文件大小,并進(jìn)行比較:
一、通過(guò)length方法:
1、創(chuàng)建一個(gè)文件:
File file = new File("E:\\全部軟件\\軟件壓縮包\\Windows7_W64_SP1_ent.iso");
2、獲取文件大?。?/p>
/** * 獲取文件長(zhǎng)度 * @param file */ public static void getFileSize1(File file) { if (file.exists() && file.isFile()) { String fileName = file.getName(); System.out.println("文件"+fileName+"的大小是:"+file.length()); } }
3、查看結(jié)果:
可見(jiàn),使用length方法獲取的文件大小與windows中顯示的大小一致!
二、通過(guò)file.io.*中的流式方法獲取
1、創(chuàng)建一個(gè)文件
依舊使用上面的文件
File file = new File("E:\\全部軟件\\軟件壓縮包\\Windows7_W64_SP1_ent.iso");
2、使用available方法獲?。?/p>
/** * 根據(jù)java.io.*的流獲取文件大小 * @param file */ public static void getFileSize2(File file){ FileInputStream fis = null; try { if(file.exists() && file.isFile()){ String fileName = file.getName(); fis = new FileInputStream(file); System.out.println("文件"+fileName+"的大小是:"+fis.available()+"\n"); } } catch (Exception e) { e.printStackTrace(); }finally{ if(null!=fis){ try { fis.close(); } catch (IOException e) { e.printStackTrace(); } } } }
3、查看結(jié)果:
通過(guò)這種方法獲取的文件大小是2147483647,很明顯,這是int類(lèi)型所能表示的最大值2^31-1,究其原因是因?yàn)槲募拇笮〕^(guò)了int所能表示的最大值?。?!
file.length()方法返回的類(lèi)型:
available()方法返回的類(lèi)型:
三、通過(guò)file.nio.*中的FileChannel工具來(lái)獲取文件大?。?/strong>
1、創(chuàng)建一個(gè)文件
依舊使用相同的大文件:
File file1 = new File("E:\\全部軟件\\軟件程序\\httpwatch.exe");
2、使用FileChannel獲取文件大小:
/** * 根據(jù)java.nio.*的流獲取文件大小 * @param file */ public static void getFileSize3(File file){ FileChannel fc = null; try { if(file.exists() && file.isFile()){ String fileName = file.getName(); FileInputStream fis = new FileInputStream(file); fc = fis.getChannel(); System.out.println("文件"+fileName+"的大小是:"+fc.size()+"\n"); } } catch (Exception e) { e.printStackTrace(); }finally{ if(null!=fc){ try { fc.close(); } catch (IOException e) { e.printStackTrace(); } } } }
3、查看結(jié)果:
可見(jiàn)通過(guò)這種方法獲取的文件大小和第一種一樣,都能獲取文件實(shí)際大小。
四、使用小文件測(cè)試以上三種方法:
以上情況中文件大小超過(guò)了available()返回類(lèi)型int的最大值,下面使用一個(gè)沒(méi)有超過(guò)int最大值的文件測(cè)試,來(lái)驗(yàn)證通過(guò)這三種方法獲取的大小是否和windows中顯示的一致:
1、獲取文件,查看其在windows中的大?。?/p>
2、將該文件單位轉(zhuǎn)成Byte:
可見(jiàn)該文件總共有28147712個(gè)字節(jié)。
3、查看通過(guò)三種方法獲取的結(jié)果:
根據(jù)結(jié)果得知,三種方法獲取的大小一致,只是跟文件的實(shí)際大小有一些誤差!!
本以為是文件類(lèi)型的原因,于是又試了大小差不多的不同類(lèi)型文件,結(jié)果發(fā)現(xiàn)絕大多數(shù)情況下只有300M以上的文件才能獲取最準(zhǔn)確的文件大小,300M以下的都會(huì)有一定的誤差!
參考了http://www.dbjr.com.cn/article/98843.htm這篇文章,但是里面沒(méi)測(cè)試300M以下的文件。
下面是我使用不同大小的文件進(jìn)行的測(cè)試,通過(guò)文件在windows中顯示的大小、轉(zhuǎn)化成單位Byte后與java獲取的方式對(duì)比,并計(jì)算出誤差值:
總結(jié)java獲取文件大小:
1、三種方法獲取小文件(300M以下)時(shí)結(jié)果一致,但是與windows顯示的值有一定誤差;
2、獲取大文件時(shí),為避免文件長(zhǎng)度大于方法返回值類(lèi)型的最大值,盡量使用length或FileChannel方法獲??;
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot使用Sharding-JDBC實(shí)現(xiàn)數(shù)據(jù)分片和讀寫(xiě)分離的方法
本文主要介紹了SpringBoot使用Sharding-JDBC實(shí)現(xiàn)數(shù)據(jù)分片和讀寫(xiě)分離,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-10-10Java 數(shù)據(jù)結(jié)構(gòu)與算法系列精講之環(huán)形鏈表
無(wú)論是靜態(tài)鏈表還是動(dòng)態(tài)鏈表,有時(shí)在解決具體問(wèn)題時(shí),需要我們對(duì)其結(jié)構(gòu)進(jìn)行稍微地調(diào)整。比如,可以把鏈表的兩頭連接,使其成為了一個(gè)環(huán)狀鏈表,通常稱為循環(huán)鏈表2022-02-02使用springboot跳轉(zhuǎn)到指定頁(yè)面和(重定向,請(qǐng)求轉(zhuǎn)發(fā)的實(shí)例)
這篇文章主要介紹了使用springboot跳轉(zhuǎn)到指定頁(yè)面和(重定向,請(qǐng)求轉(zhuǎn)發(fā)的實(shí)例),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-12-12Java實(shí)現(xiàn)簡(jiǎn)單樹(shù)結(jié)構(gòu)
這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)簡(jiǎn)單樹(shù)結(jié)構(gòu)的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-01-01springboot?log4j2日志框架整合與使用過(guò)程解析
這篇文章主要介紹了springboot?log4j2日志框架整合與使用,包括引入maven依賴和添加配置文件log4j2-spring.xml的相關(guān)知識(shí),需要的朋友可以參考下2022-05-05K均值聚類(lèi)算法的Java版實(shí)現(xiàn)代碼示例
這篇文章主要介紹了K均值聚類(lèi)算法的Java版實(shí)現(xiàn)代碼示例,具有一定借鑒價(jià)值,需要的朋友可以參考下。2017-12-12Springboot集成Kafka實(shí)現(xiàn)producer和consumer的示例代碼
這篇文章主要介紹了Springboot集成Kafka實(shí)現(xiàn)producer和consumer的示例代碼,詳細(xì)的介紹了什么是Kafka和安裝Kafka以及在springboot項(xiàng)目中集成kafka收發(fā)message,感興趣的小伙伴們可以參考一下2018-05-05