Java处理大文件

Posted 幽幽子

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java处理大文件相关的知识,希望对你有一定的参考价值。

  对于小文件中的内容,在进行处理的时候,可以简单地将其全部加载到内存中,而后进行处理:

        /**
         * 将文件内容全部读取到内存中
         */
        try {
            List<String> list = FileUtils.readLines(new File(fileDerec), Charsets.UTF_8);
            System.out.println(list.get(0));
        } catch (IOException e) {
            e.printStackTrace();
        }

  但是处理大文件(GB级)时,如果简单地将其加载到内存中,可能会导致内存溢出。所以通常会用以下的办法对其进行处理:

        /**
         * java.util.*文件流处理
         */
        FileInputStream fi = null;
        Scanner sc = null;
        try {
            fi = new FileInputStream(new File(fileDerec));
            sc = new Scanner(fi, "UTF-8");
            if (sc.hasNextLine()) {
                System.out.println(sc.nextLine());
            }
        } catch (Exception e) {
        } finally {
            if (fi != null) {
                try {
                    fi.close();
                } catch (IOException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }
            }
            if (sc != null) {
                sc.close();
            }
        }

  也可以使用第三方使用的包:

        /**
         * Apache-commons-io提供的流处理
         */
        LineIterator li = null;
        try {
            li = FileUtils.lineIterator(new File(fileDerec), "UTF-8");
            if (li.hasNext()) {
                System.out.println(li.next());
            }
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } finally {
            LineIterator.closeQuietly(li);
        }

 

以上是关于Java处理大文件的主要内容,如果未能解决你的问题,请参考以下文章

VSCode自定义代码片段13——Vue的状态大管家

VSCode自定义代码片段13——Vue的状态大管家

java.util.MissingResourceException: Can't find bundle for base name init, locale zh_CN问题的处理(代码片段

java 反射代码片段

java 读取大数据文件,处理大数据文件性能比较?

如何有效地打开 30gb 的文件并处理其中的片段而不减慢速度?