RandomAccessSource not opened

       最近在使用word模板生成pdf,一开始由于一些流没有关闭,导致内存溢出,出现"too many open files",后来就对代码中流和读写对象一通关闭。

        代码调整之后,本以为可以完美的解决问题,结果又出现一个莫名的异常“java.io.IOException: RandomAccessSource not opened”,问度娘吧,没有找到合理的解决办法。然后就可以研究代码,从代码上看,真没什么问题啊。

        之后就不禁怀疑,是不是哪里的流关早了,还是不该关的流关错了。

        从堆栈信息来看,发现异常是打在pdfStamper.close()方法上的,

        RandomAccessSource not opened

    最后查看代码,在关闭stamper之前,关闭了构建stamper对象的os和reader,如下:

    RandomAccessSource not opened

最后将stamper.close()放到最上边,即先关闭stamper,在关闭os和reader,测试一下,完美解决!!!终于可以歇歇了