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();
    }
}

questionAnswers(2)

yourAnswerToTheQuestion