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

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java io流如何读取文件效率高相关的知识,希望对你有一定的参考价值。

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

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

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

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

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

而InputStream声明的数组是:byte[] bs = new byte[1024]
参考技术A 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内存)
参考技术B 慢看、。。。要有耐心

以上是关于java io流如何读取文件效率高的主要内容,如果未能解决你的问题,请参考以下文章

java文件读写

java 文件读写流

java如何读取文件流是啥格式

java怎么使用io流读取一个文件夹里面

java io流(字符流) 文件打开读取文件关闭文件

java 中简述使用流进行读写文本文件的步骤?