打开文件错误太多,java.io.FileNotFoundException

前端之家收集整理的这篇文章主要介绍了打开文件错误太多,java.io.FileNotFoundException前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

在我的程序中,我有循环扫描一堆文件并读取其内容.问题发生在大约1500个文件的迭代中,似乎无法再现(或理解(由我))

问题:

java.io.FileNotFoundException: /path/to/file//myFile (Too many open files)

方法的例外情况如下:

private static String readFileAsRawString(File f) throws IOException {

    FileInputStream stream = new FileInputStream(f); // <------------Stacktrace
    try{
      FileChannel fc = stream.getChannel();
      MappedByteBuffer bb = fc.map(FileChannel.MapMode.READ_ONLY,fc.size());

      return Charset.defaultCharset().decode(bb).toString();
    } finally {
        stream.close();
    }
}

我在QA中运行了这个方法超过20,000个文件,它似乎没有任何问题.

您是否看到上面粘贴的代码有什么问题导致此问题?

最佳答案
映射是可疑的. MappedByteBuffer可以比它的FileChannel更长,并且在垃圾收集之前一直有效.您可能没有足够的垃圾来运行GC,但可能在特定平台上,文件句柄由未引用的缓冲区保留.

除非禁用显式垃圾收集(-XX:-DisableExplicitGC),否则您应该能够通过捕获异常,调用System.gc()并再次尝试来测试此问题.如果它在第二次尝试时起作用,那就是你的问题.但是,将System.gc()作为永久修复程序调用是一个坏主意.整体表现最佳的解决方案将在目标平台上进行一些分析.

猜你在找的Java相关文章