好久没写东西了,最近太忙了。今天做文件的操作发现点有趣的现象。放上来跟大家分享一下。
今天用IDEA做程序的本地文件的部分时,碰到一点小问题。程序如下:
1 package example;
2
3 import java.io.BufferedReader;
4 import java.io.File;
5 import java.io.FileNotFoundException;
6 import java.io.FileReader;
7 import java.io.IOException;
8
9
10
11 public class FileOperation {
12
13 /**
14 * @param args
15 */
16 public static void main(String[] args) {
17 // TODO Auto-generated method stub
18 FileOperation fo = new FileOperation();
19 String s = "";
20 try {
21 s = fo.bufferedReaderDemo("D:/Project/IntelliJ/BrowseVisual/Resource/res/fo1.txt");
22 } catch (IOException e) {
23 // TODO Auto-generated catch block
24 e.printStackTrace();
25 }
26
27 System.out.println(s);
28
29 }
30
31 public String bufferedReaderDemo(String filename) throws IOException {
32 File file = new File(filename);
33 if (!file.exists() || file.isDirectory()) {
34 throw new FileNotFoundException();
35 }
36 BufferedReader br = new BufferedReader(new FileReader(file));
37 String temp;
38 StringBuffer sb = new StringBuffer();
39 temp = br.readLine();
40 while (temp != null) {
41 sb.append(temp).append(" ");
42 temp = br.readLine();
43 }
44 System.out.println(sb.length());
45
46 return sb.toString();
47 }
48
49 }
程序运行,IDEA输出空白,整个IDEA近乎进入假死状态。哪儿出问题了呢?经过排查否定了String和StringBuffer的问题,后来查看fo1.txt的文件格式居然是utf-8,难道跟这个有关系?经过测试,当fo1.txt只有10几K的情况下,没有问题,输出乱码,而当fo1.txt达到几十K的时候,IDEA就没法正常输出了,当fo1.txt文件格式改为gbk的话,文件1M照样正常运行。后又拿Eclipse测试,fo1.txt在utf-8下1M大小正常输出乱码(不过感觉好慢,除了IDEA那个假死状态,程序在正常运行情况下,感觉Eclipse比IDEA慢上不少,有点难以忍受了)。
嗯。写这个出来,只是想大家探讨探讨这到底是什么问题呢?为啥IDEA会出现这种状况呢?马上去NetBeans里测试测试。