Java中的IO的性能优化
在使用IO的时候注意一下细节,能使性能得到很大的优化.
首先读写大文件,使用Buffer是肯定的了,使用方法,有下边两个
1
方法一:
2
public
static
void
test1(String fileName)
{
3
long start = System.currentTimeMillis();
4
try
{
5
FileInputStream fis = new FileInputStream(fileName);
6
BufferedReader br = new BufferedReader( new InputStreamReader(fis) );
7
StringBuffer sb = new StringBuffer();
8
String str;
9
while ((str = br.readLine()) != null )
{
10
sb.append(str);
11
}
12
} catch (IOException e)
{
13
}
14
long end = System.currentTimeMillis();
15
long time = end - start;
16
System.out.println(time);
17
}
18
方法二:
19
public
static
void
test2(String fileName)
{
20
long start = System.currentTimeMillis();
21
try
{
22
FileInputStream fis = new FileInputStream(fileName);
23
byte buf[] = new byte [ 8192 ];
24
int n;
25
StringBuffer sb = new StringBuffer();
26
while ((n = fis.read(buf)) != - 1 )
{
27
sb.append(buf);
28
}
29
fis.close();
30
} catch (IOException e)
{
31
}
32
long end = System.currentTimeMillis();
33
long time = end - start;
34
System.out.println(time);
35
}
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123143807.gif)
2
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144414.gif)
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144718.gif)
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144283.gif)
3
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
4
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144122.gif)
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144421.gif)
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144283.gif)
5
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
6
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
7
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
8
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
9
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144122.gif)
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144421.gif)
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144283.gif)
10
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
11
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123145279.gif)
12
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144122.gif)
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144421.gif)
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144283.gif)
13
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123145279.gif)
14
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
15
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
16
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
17
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123145488.gif)
18
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123143807.gif)
19
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144414.gif)
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144718.gif)
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144283.gif)
20
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
21
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144122.gif)
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144421.gif)
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144283.gif)
22
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
23
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
24
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
25
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
26
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144122.gif)
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144421.gif)
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144283.gif)
27
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
28
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123145279.gif)
29
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
30
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144122.gif)
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144421.gif)
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144283.gif)
31
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123145279.gif)
32
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
33
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
34
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
35
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123145488.gif)
方法一1937ms
方法二47ms
测试结果相差大概50倍左有,很大。
而我平时的习惯是方法一。问题主要出在readLine()上。
如果只是简单的文件拷贝,下边两种方法也不错
1
public
static
void
test3()
{
2
String cmd = " copy d:/out1.txt out2.txt " ;
3
try
{
4
Runtime.getRuntime().exec(cmd);
5
} catch (Exception e)
{
6
e.printStackTrace();
7
}
8
}
9
public
static
void
test4()
{
10
String inFileName = " d:/out1.txt " ;
11
String outFileName = " d:/out2.txt " ;
12
long start = System.currentTimeMillis();
13
try
{
14
File inFile = new File(inFileName);
15
File outFile = new File(outFileName);
16
RandomAccessFile inRaf = new RandomAccessFile(inFile, " r " );
17
RandomAccessFile outRaf = new RandomAccessFile(outFile, " rw " );
18
FileChannel infc = inRaf.getChannel();
19
FileChannel outfc = outRaf.getChannel();
20
infc.transferTo( 0 , inFile.length(),outfc );
21
infc.close();
22
outfc.close();
23
} catch (Exception e)
{
24
e.printStackTrace();
25
}
26
long end = System.currentTimeMillis();
27
long time = end - start;
28
System.out.println(time);
29
}
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144414.gif)
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144718.gif)
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144283.gif)
2
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
3
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144122.gif)
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144421.gif)
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144283.gif)
4
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
5
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144122.gif)
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144421.gif)
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144283.gif)
6
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
7
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123145279.gif)
8
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123145488.gif)
9
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144414.gif)
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144718.gif)
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144283.gif)
10
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
11
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
12
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
13
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144122.gif)
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144421.gif)
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144283.gif)
14
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
15
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
16
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
17
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
18
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
19
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
20
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
21
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
22
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
23
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144122.gif)
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144421.gif)
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144283.gif)
24
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
25
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123145279.gif)
26
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
27
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
28
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123144623.gif)
29
![](http://www.j2medev.com/Article/UploadFiles/200611/20061117123145488.gif)