前端之家收集整理的这篇文章主要介绍了
利用FOP将xml转换成PDF,有时PDF会破损,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
PDF破损的原因是,在变换过程中发生了内存泄露的错误。
内存泄露的原因如下:
1.PDF文档最后会根据已有的文字,从对应的字体库中读取对应的字体信息附在文件后面,由于要搜索对应字符的字体信息,所以FOP实现中采用了将整个字体文件读入内存中作为一个数组进行查询,这对于西方文字来说,整个字体文件大约300k,不会出现很大问题;但是对于亚洲语种来说,一个字体文件可能就是 10几M,譬如我们常用的宋体,在windows中就是10M,无疑将文档生成后期,内存已经是被JVM申请释放搞得碎片多多,从而要求一整片10M的空间会使得JVM无法处理,
而最后只有OutOfMemoryError。
2.PDF对于图片的处理则是先从图片文件中提取所有的点阵信息,放在一片数组内存中,然后在写入PDF文件的时候则采用类似PNG图片的压缩方法(是否就是PNG所使用的LZ77压缩算法还要研究查实)将这些点阵数组内存中的数据压缩写入文件的方法。这个过程中会由于实现的原因会使得存在两个点阵数组,譬如针对1024x1024的图片,则要求同时存在一个4x1024x1024和一个3x1024x1024的内存片,其中4是 sizeof(int),而3是sizeof(r,g,b),如此就对内存的申请导致了和字体文件同样的问题,就是最后因为JVM内部的碎片问题导致内存不足而报OutOfMemoryError。
解决方法:
增加FOP处理所需的内存空间。