我在循环中使用 ImageIO.read(InputStream is) 从远程服务器(HttpConnection 和 InputStream)制作 BufferedImages
但是,它每次都会发生内存不足的java堆空间。
我不知道为什么会这样。
这是我的 jvm 参数选项。
-verbosegc -XX:+PrintGCDetails -Xmx1024m - XX:PermSize=128m
和完整的 gc 日志。
[Full GC [PSYoungGen: 506K->0K(6656K)] [PSOldGen: 963K->1457K(5504K)] 1469K-
>1457K(12160K) [PSPermGen: 8556K->8556K(131072K)], 0.0155080 secs]
[Full GC [PSYoungGen: 480K->0K(11072K)] [PSOldGen: 5001K->4697K(11456K)]
5481K->4697K(22528K) [PSPermGen: 18222K->18222K(131072K)], 0.0350780
5481K->secs]
如您所见,在younggen和oldgen,permgen中有可用空间。那是最后一个完整的 gc 日志。
登录后,jvm 因内存不足而关闭。
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
at java.awt.color.ICC_Profile.getData(ICC_Profile.java:1315)
at java.awt.color.ICC_Profile.getInstance(ICC_Profile.java:762)
at com.sun.imageio.plugins.jpeg.JPEGImageReader.setImageData(JPEGImageReader.java:610)
at com.sun.imageio.plugins.jpeg.JPEGImageReader.readImageHeader(Native Method)
at com.sun.imageio.plugins.jpeg.JPEGImageReader.readNativeHeader(JPEGImageReader.java:561)
at com.sun.imageio.plugins.jpeg.JPEGImageReader.checkTablesOnly(JPEGImageReader.java:316)
at com.sun.imageio.plugins.jpeg.JPEGImageReader.gotoImage(JPEGImageReader.java:438)
at com.sun.imageio.plugins.jpeg.JPEGImageReader.readHeader(JPEGImageReader.java:554)
at com.sun.imageio.plugins.jpeg.JPEGImageReader.readInternal(JPEGImageReader.java:940)
at com.sun.imageio.plugins.jpeg.JPEGImageReader.read(JPEGImageReader.java:924)
at javax.imageio.ImageIO.read(ImageIO.java:1400)
at javax.imageio.ImageIO.read(ImageIO.java:1322)
请帮忙。谢谢。
我很抱歉我的问题。
我已经发布了我的来源。它从图像中提取哈希码。
1.主要代码。
HashExtractor h = new HashExtractor();
while(rs.next()) {
Inputstream is = getStream();
h.doSomething(is);
//something to do using bi.
is.close();
}
//in HashExtractor
public String doSomething(InputStream is) {
BufferedImage bi = ImageIO.read(is);
String hash = "";
//extract hash.
return hash;
}
我删除了一些细节,看起来很容易。(获得连接..等)
谢谢!