1、通過file的length()方法獲取;
2、通過流式方法獲取;
通過流式方法又有兩種,分別是舊的java.io.*中fileinputstream的available()方法和新的java..nio.*中的filechannel
下面依次介紹這幾種方法:
首先選擇一個文件并查看這個文件在windows中顯示的大小,為了測試準確性,我這里選取了一個大文件(超過2gb)
查看這個文件在windows中顯示的大?。?/p>
使用在線轉換工具將其轉換成字節:
可以看出這個文件的實際大小是3265574912byte,下面通過代碼來獲取文件大小,并進行比較:
一、通過length方法:
1、創建一個文件:
1
|
file file = new file( "e:\\全部軟件\\軟件壓縮包\\windows7_w64_sp1_ent.iso" ); |
2、獲取文件大?。?/p>
1
2
3
4
5
6
7
8
9
10
|
/** * 獲取文件長度 * @param file */ public static void getfilesize1(file file) { if (file.exists() && file.isfile()) { string filename = file.getname(); system.out.println( "文件" +filename+ "的大小是:" +file.length()); } } |
3、查看結果:
可見,使用length方法獲取的文件大小與windows中顯示的大小一致!
二、通過file.io.*中的流式方法獲取
1、創建一個文件
依舊使用上面的文件
1
|
file file = new file( "e:\\全部軟件\\軟件壓縮包\\windows7_w64_sp1_ent.iso" ); |
2、使用available方法獲?。?/p>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
/** * 根據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、查看結果:
通過這種方法獲取的文件大小是2147483647,很明顯,這是int類型所能表示的最大值2^31-1,究其原因是因為文件的大小超過了int所能表示的最大值?。。?/p>
file.length()方法返回的類型:
available()方法返回的類型:
三、通過file.nio.*中的filechannel工具來獲取文件大?。?/strong>
1、創建一個文件
依舊使用相同的大文件:
1
|
file file1 = new file( "e:\\全部軟件\\軟件程序\\httpwatch.exe" ); |
2、使用filechannel獲取文件大?。?/p>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
/** * 根據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、查看結果:
可見通過這種方法獲取的文件大小和第一種一樣,都能獲取文件實際大小。
四、使用小文件測試以上三種方法:
以上情況中文件大小超過了available()返回類型int的最大值,下面使用一個沒有超過int最大值的文件測試,來驗證通過這三種方法獲取的大小是否和windows中顯示的一致:
1、獲取文件,查看其在windows中的大小:
2、將該文件單位轉成byte:
可見該文件總共有28147712個字節。
3、查看通過三種方法獲取的結果:
根據結果得知,三種方法獲取的大小一致,只是跟文件的實際大小有一些誤差?。?/p>
本以為是文件類型的原因,于是又試了大小差不多的不同類型文件,結果發現絕大多數情況下只有300m以上的文件才能獲取最準確的文件大小,300m以下的都會有一定的誤差!
參考了http://www.ythuaji.com.cn/article/83503.html這篇文章,但是里面沒測試300m以下的文件。
下面是我使用不同大小的文件進行的測試,通過文件在windows中顯示的大小、轉化成單位byte后與java獲取的方式對比,并計算出誤差值:
總結java獲取文件大?。?/p>
1、三種方法獲取小文件(300m以下)時結果一致,但是與windows顯示的值有一定誤差;
2、獲取大文件時,為避免文件長度大于方法返回值類型的最大值,盡量使用length或filechannel方法獲取;
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。
原文鏈接:http://www.cnblogs.com/hellowhy/p/7238570.html