1、通过file的length()方法获取;
2、通过流式方法获取;
通过流式方法又有两种,分别是旧的java.io.*中fileinputstream的available()方法和新的java..nio.*中的filechannel
下面依次介绍这几种方法:
首先选择一个文件并查看这个文件在windows中显示的大小,为了测试准确性,我这里选取了一个大文件(超过2gb)
查看这个文件在windows中显示的大小:
使用在线转换工具将其转换成字节:
可以看出这个文件的实际大小是3265574912byte,下面通过代码来获取文件大小,并进行比较:
一、通过length方法:
1、创建一个文件:
1
|
file file = new file( "e:\\全部软件\\软件压缩包\\windows7_w64_sp1_ent.iso" );
|
2、获取文件大小:
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方法获取:
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所能表示的最大值!!!
file.length()方法返回的类型:
available()方法返回的类型:
三、通过file.nio.*中的filechannel工具来获取文件大小:
1、创建一个文件
依旧使用相同的大文件:
1
|
file file1 = new file( "e:\\全部软件\\软件程序\\httpwatch.exe" );
|
2、使用filechannel获取文件大小:
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、查看通过三种方法获取的结果:
根据结果得知,三种方法获取的大小一致,只是跟文件的实际大小有一些误差!!
本以为是文件类型的原因,于是又试了大小差不多的不同类型文件,结果发现绝大多数情况下只有300m以上的文件才能获取最准确的文件大小,300m以下的都会有一定的误差!
参考了http://www.zzvips.com/article/83503.html这篇文章,但是里面没测试300m以下的文件。
下面是我使用不同大小的文件进行的测试,通过文件在windows中显示的大小、转化成单位byte后与java获取的方式对比,并计算出误差值:
总结java获取文件大小:
1、三种方法获取小文件(300m以下)时结果一致,但是与windows显示的值有一定误差;
2、获取大文件时,为避免文件长度大于方法返回值类型的最大值,尽量使用length或filechannel方法获取;
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://www.cnblogs.com/hellowhy/p/7238570.html