uso excessivo de memória por java
Em um projeto meu, comprimo constantemente pequenos blocos de dados. Agora eu descubro que a jvm cresce para 6 GB de RAM (RAM residente), não compartilhada ou virtual) e depois morre por falta de memória. É como se o coletor de lixo nunca funcionasse mais ou menos. Peguei o código relevante e colei abaixo. Quando eu o executo (java6, linux de 32 bits), ele cresce para 1 GB de RAM. Alguém teve uma idéia de como reduzir o uso de memória?
import java.util.Random;
import java.util.zip.Deflater;
import java.util.zip.Inflater;
class test {
int blockSize = 4096;
Random r = new Random();
public test() throws Exception {
blockSize = 4096;
byte [] data = new byte[blockSize];
for(int index=0; index<blockSize; index++)
data[index] = (byte)r.nextInt();
for(long cnt=0; cnt<1000000; cnt++) {
byte [] result = compress(data);
if (result != null)
data[0] = result[0];
}
}
byte [] compress(byte [] in) {
assert in.length == blockSize;
Deflater compresser = new Deflater();
compresser.setInput(in);
compresser.finish();
byte [] out = new byte[in.length];
int outLen = compresser.deflate(out);
if (outLen < blockSize) {
byte [] finalOut = new byte[outLen];
System.arraycopy(out, 0, finalOut, 0, outLen);
return finalOut;
}
return null;
}
public static void main(String [] args) throws Exception {
new test();
}
}