|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object org.apache.lucene.util.encoding.IntEncoder
public abstract class IntEncoder
Encodes integers to a set OutputStream
. Extending classes need to
override encode(int)
to encode the value using their encoding
algorithm. The default implementation of close()
closes the set
OutputStream
.
The default constructor
is provided for convenience
only. One must call reInit(OutputStream)
before calling
encode(int)
or close()
.
For convenience, each encoder implements createMatchingDecoder()
for
easy access to the matching decoder.
NOTE: some implementations may buffer the encoded values in memory
(such as IntEncoderFilter
implementations) and encoding will happen
only upon calling close()
. Therefore it is important to always call
close()
on the encoder at hand.
NOTE: encoders are usually not thread safe, unless specifically documented otherwise by an implementation.
Field Summary | |
---|---|
protected OutputStream |
out
|
Constructor Summary | |
---|---|
IntEncoder()
Default constructor, provided here for robustness: if in the future a constructor with parameters will be added, this might break custom implementations of this class which call this implicit constructor. |
Method Summary | |
---|---|
void |
close()
Instructs the encoder to finish the encoding process. |
abstract IntDecoder |
createMatchingDecoder()
Returns an IntDecoder which matches this encoder. |
abstract void |
encode(int value)
Encodes an integer to the output stream given in reInit |
void |
reInit(OutputStream out)
Reinitializes the encoder with the give OutputStream . |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
---|
protected OutputStream out
Constructor Detail |
---|
public IntEncoder()
Method Detail |
---|
public void close() throws IOException
reInit
. An implementation may do here additional cleanup required to
complete the encoding, such as flushing internal buffers, etc.encode
should be made before first calling reInit
.
NOTE: overriding classes should make sure they either call
super.close()
or close the output stream themselves.
IOException
public abstract void encode(int value) throws IOException
reInit
IOException
public abstract IntDecoder createMatchingDecoder()
IntDecoder
which matches this encoder. Every encoder
must return an IntDecoder
and null
is not a valid
value. If an encoder is just a filter, it should at least return its
wrapped encoder's matching decoder.
NOTE: this method should create a new instance of the matching decoder and leave the instance sharing to the caller. Returning the same instance over and over is risky because encoders and decoders are not thread safe.
public void reInit(OutputStream out)
OutputStream
. For
re-usability it can be changed without the need to reconstruct a new
object.
NOTE: after calling close()
, one must call
this method even if the output stream itself hasn't changed. An example
case is that the output stream wraps a byte[], and the output stream itself
is reset, but its instance hasn't changed. Some implementations of
IntEncoder
may write some metadata about themselves to the output
stream, and therefore it is imperative that one calls this method before
encoding any data.
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |