java獲取文件大小的幾種方法
目前Java獲取文件大小的方法有兩種:
1、通過file的length()方法獲??;
2、通過流式方法獲??;
通過流式方法又有兩種,分別是舊的java.io.*中FileInputStream的available()方法和新的java..nio.*中的FileChannel
下面依次介紹這幾種方法:
首先選擇一個(gè)文件并查看這個(gè)文件在windows中顯示的大小,為了測(cè)試準(zhǔn)確性,我這里選取了一個(gè)大文件(超過2GB)
查看這個(gè)文件在windows中顯示的大?。?/p>

使用在線轉(zhuǎn)換工具將其轉(zhuǎn)換成字節(jié):

可以看出這個(gè)文件的實(shí)際大小是3265574912Byte,下面通過代碼來獲取文件大小,并進(jìn)行比較:
一、通過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é)果:

可見,使用length方法獲取的文件大小與windows中顯示的大小一致!
二、通過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é)果:

通過這種方法獲取的文件大小是2147483647,很明顯,這是int類型所能表示的最大值2^31-1,究其原因是因?yàn)槲募拇笮〕^了int所能表示的最大值!??!
file.length()方法返回的類型:

available()方法返回的類型:

三、通過file.nio.*中的FileChannel工具來獲取文件大?。?/strong>
1、創(chuàng)建一個(gè)文件
依舊使用相同的大文件:
File file1 = new File("E:\\全部軟件\\軟件程序\\httpwatch.exe");
2、使用FileChannel獲取文件大?。?/p>
/**
* 根據(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é)果:

可見通過這種方法獲取的文件大小和第一種一樣,都能獲取文件實(shí)際大小。
四、使用小文件測(cè)試以上三種方法:
以上情況中文件大小超過了available()返回類型int的最大值,下面使用一個(gè)沒有超過int最大值的文件測(cè)試,來驗(yàn)證通過這三種方法獲取的大小是否和windows中顯示的一致:
1、獲取文件,查看其在windows中的大小:

2、將該文件單位轉(zhuǎn)成Byte:

可見該文件總共有28147712個(gè)字節(jié)。
3、查看通過三種方法獲取的結(jié)果:

根據(jù)結(jié)果得知,三種方法獲取的大小一致,只是跟文件的實(shí)際大小有一些誤差??!
本以為是文件類型的原因,于是又試了大小差不多的不同類型文件,結(jié)果發(fā)現(xiàn)絕大多數(shù)情況下只有300M以上的文件才能獲取最準(zhǔn)確的文件大小,300M以下的都會(huì)有一定的誤差!
參考了http://chabaoo.cn/article/98843.htm這篇文章,但是里面沒測(cè)試300M以下的文件。
下面是我使用不同大小的文件進(jìn)行的測(cè)試,通過文件在windows中顯示的大小、轉(zhuǎn)化成單位Byte后與java獲取的方式對(duì)比,并計(jì)算出誤差值:

總結(jié)java獲取文件大?。?/p>
1、三種方法獲取小文件(300M以下)時(shí)結(jié)果一致,但是與windows顯示的值有一定誤差;
2、獲取大文件時(shí),為避免文件長(zhǎng)度大于方法返回值類型的最大值,盡量使用length或FileChannel方法獲取;
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot使用Sharding-JDBC實(shí)現(xiàn)數(shù)據(jù)分片和讀寫分離的方法
本文主要介紹了SpringBoot使用Sharding-JDBC實(shí)現(xiàn)數(shù)據(jù)分片和讀寫分離,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-10-10
Java 數(shù)據(jù)結(jié)構(gòu)與算法系列精講之環(huán)形鏈表
無論是靜態(tài)鏈表還是動(dòng)態(tài)鏈表,有時(shí)在解決具體問題時(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-12
Java實(shí)現(xiàn)簡(jiǎn)單樹結(jié)構(gòu)
這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)簡(jiǎn)單樹結(jié)構(gòu)的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-01-01
springboot?log4j2日志框架整合與使用過程解析
這篇文章主要介紹了springboot?log4j2日志框架整合與使用,包括引入maven依賴和添加配置文件log4j2-spring.xml的相關(guān)知識(shí),需要的朋友可以參考下2022-05-05
K均值聚類算法的Java版實(shí)現(xiàn)代碼示例
這篇文章主要介紹了K均值聚類算法的Java版實(shí)現(xiàn)代碼示例,具有一定借鑒價(jià)值,需要的朋友可以參考下。2017-12-12
Springboot集成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

