java io流如何读取文件效率高

看了好多人在使用流时 定义一个1024字节数组 如果读取字节数不够1024貌似有时会又乱码,我记得inputstream有个方法 available() 可以直接指定长度 但是我又担心一口气定义的数组长度太长会不会影响性能,求教育,谢谢

你在类的使用上不太恰当。

如果你想读取文本内容,你应该使用InputStreamReader这个类,使用这个类并且指定文本内容的字符集,就可以读出正确的内容。

InputStream这个类是用来读取二进制字节的,比如做文件复制的时候,应该是用InputStream这个类。

不管是InputStreamReader还是InputStream,都可以声明临时缓冲数组,不同的是InputStreamReader声明的数组是:char[] cs = new char[1024]

而InputStream声明的数组是:byte[] bs = new byte[1024]
温馨提示:内容为网友见解,仅供参考
第1个回答  2015-07-07
java提供了搞笑读取文件的方式:文件流,下面以FileInputStream和Apache Commons IO流两种读取方式来详细讲解:

以下两种代码均是读取一个大约1G的文件:

1、文件流
FileInputStream inputStream = null;
Scanner sc = null;
try {
inputStream = new FileInputStream(path);
sc = new Scanner(inputStream, "UTF-8");
while (sc.hasNextLine()) {
String line = sc.nextLine();
// System.out.println(line);
}
// note that Scanner suppresses exceptions
if (sc.ioException() != null) {
throw sc.ioException();
}
} finally {
if (inputStream != null) {
inputStream.close();
}
if (sc != null) {
sc.close();
}
}
这种方案将会遍历文件中的所有行——允许对每一行进行处理,而不保持对它的引用。总之没有把它们存放在内存中:(大约消耗了150MB内存)

2、Apache Commons IO流
同样也可以使用Commons IO库实现,利用该库提供的自定义LineIterator:
LineIterator it = FileUtils.lineIterator(theFile, "UTF-8");
try {
while (it.hasNext()) {
String line = it.nextLine();
// do something with line
}
} finally {
LineIterator.closeQuietly(it);
}
由于整个文件不是全部存放在内存中,这也就导致相当保守的内存消耗:(大约消耗了150MB内存)
第2个回答  2013-03-24
慢看、。。。要有耐心
相似回答