public final class CompressLZF extends Object
This class implements the LZF lossless data compression algorithm. LZF is a Lempel-Ziv variant with byte-aligned output, and optimized for speed.
Safety/Use Notes:
The LZF compressed format knows literal runs and back-references:
The first byte of the compressed stream is the control byte. For literal runs, the highest three bits of the control byte are not set, the the lower bits are the literal run length, and the next bytes are data to copy directly into the output. For back-references, the highest three bits of the control byte are the back-reference length. If all three bits are set, then the back-reference length is stored in the next byte. The lower bits of the control byte combined with the next byte form the offset for the back-reference.
Constructor and Description |
---|
CompressLZF() |
Modifier and Type | Method and Description |
---|---|
int |
compress(byte[] in,
int inLen,
byte[] out,
int outPos) |
void |
expand(ByteBuffer in,
int inPos,
byte[] out,
int outPos,
int outLen) |
void |
expand(DataInput in,
byte[] out,
int outPos,
int outLen) |
public int compress(byte[] in, int inLen, byte[] out, int outPos)
public void expand(DataInput in, byte[] out, int outPos, int outLen) throws IOException
IOException
public void expand(ByteBuffer in, int inPos, byte[] out, int outPos, int outLen)
Copyright © 2016. All rights reserved.