Package org.apache.avro.io
Class BinaryEncoder
java.lang.Object
org.apache.avro.io.Encoder
org.apache.avro.io.BinaryEncoder
- All Implemented Interfaces:
- Flushable
- Direct Known Subclasses:
- BufferedBinaryEncoder,- DirectBinaryEncoder
An abstract 
Encoder for Avro's binary encoding.
 
 To construct and configure instances, use EncoderFactory- See Also:
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionabstract intReturns the number of bytes currently buffered by this encoder.voidsetItemCount(long itemCount) Call this method before writing a batch of items in an array or a map.voidStart a new item of an array or map.voidCall this method to finish writing an array.voidCall this method to start writing an array.voidwriteBytes(byte[] bytes, int start, int len) Write a byte string.voidwriteBytes(ByteBuffer bytes) Write a byte string.voidwriteEnum(int e) Writes an enumeration.voidwriteIndex(int unionIndex) Call this method to write the tag of a union.voidCall this method to terminate the inner-most, currently-opened map.voidCall this to start a new map.void"Writes" a null value.voidwriteString(String string) Write a Unicode character string.voidwriteString(Utf8 utf8) Write a Unicode character string.protected abstract voidWrite a zero byte to the underlying output.Methods inherited from class org.apache.avro.io.EncoderwriteBoolean, writeBytes, writeDouble, writeFixed, writeFixed, writeFixed, writeFloat, writeInt, writeLong, writeString
- 
Constructor Details- 
BinaryEncoderpublic BinaryEncoder()
 
- 
- 
Method Details- 
writeNullDescription copied from class:Encoder"Writes" a null value. (Doesn't actually write anything, but advances the state of the parser if this class is stateful.)- Specified by:
- writeNullin class- Encoder
- Throws:
- IOException
 
- 
writeStringDescription copied from class:EncoderWrite a Unicode character string.- Specified by:
- writeStringin class- Encoder
- Throws:
- IOException
 
- 
writeStringDescription copied from class:EncoderWrite a Unicode character string. The default implementation converts the String to aUtf8. Some Encoder implementations may want to do something different as a performance optimization.- Overrides:
- writeStringin class- Encoder
- Throws:
- IOException
 
- 
writeBytesDescription copied from class:EncoderWrite a byte string.- Specified by:
- writeBytesin class- Encoder
- Throws:
- IOException
 
- 
writeBytesDescription copied from class:EncoderWrite a byte string.- Specified by:
- writeBytesin class- Encoder
- Throws:
- IOException
 
- 
writeEnumDescription copied from class:EncoderWrites an enumeration.- Specified by:
- writeEnumin class- Encoder
- Parameters:
- e-
- Throws:
- IOException
 
- 
writeArrayStartDescription copied from class:EncoderCall this method to start writing an array. When starting to serialize an array, callEncoder.writeArrayStart(). Then, before writing any data for any item callEncoder.setItemCount(long)followed by a sequence ofEncoder.startItem()and the item itself. The number ofEncoder.startItem()should match the number specified inEncoder.setItemCount(long). When actually writing the data of the item, you can call anyEncodermethod (e.g.,Encoder.writeLong(long)). When all items of the array have been written, callEncoder.writeArrayEnd(). As an example, let's say you want to write an array of records, the record consisting of an Long field and a Boolean field. Your code would look something like this:out.writeArrayStart(); out.setItemCount(list.size()); for (Record r : list) { out.startItem(); out.writeLong(r.longField); out.writeBoolean(r.boolField); } out.writeArrayEnd();- Specified by:
- writeArrayStartin class- Encoder
- Throws:
- IOException
 
- 
setItemCountDescription copied from class:EncoderCall this method before writing a batch of items in an array or a map. Then for each item, callEncoder.startItem()followed by any of the other write methods ofEncoder. The number of calls toEncoder.startItem()must be equal to the count specified inEncoder.setItemCount(long). Once a batch is completed you can start another batch withEncoder.setItemCount(long).- Specified by:
- setItemCountin class- Encoder
- Parameters:
- itemCount- The number of- Encoder.startItem()calls to follow.
- Throws:
- IOException
 
- 
startItemDescription copied from class:EncoderStart a new item of an array or map. SeeEncoder.writeArrayStart()for usage information.- Specified by:
- startItemin class- Encoder
- Throws:
- IOException
 
- 
writeArrayEndDescription copied from class:EncoderCall this method to finish writing an array. SeeEncoder.writeArrayStart()for usage information.- Specified by:
- writeArrayEndin class- Encoder
- Throws:
- IOException
 
- 
writeMapStartDescription copied from class:EncoderCall this to start a new map. SeeEncoder.writeArrayStart()for details on usage. As an example of usage, let's say you want to write a map of records, the record consisting of an Long field and a Boolean field. Your code would look something like this:out.writeMapStart(); out.setItemCount(list.size()); for (Map.Entryinvalid input: '<'String, Record> entry : map.entrySet()) { out.startItem(); out.writeString(entry.getKey()); out.writeLong(entry.getValue().longField); out.writeBoolean(entry.getValue().boolField); } out.writeMapEnd();- Specified by:
- writeMapStartin class- Encoder
- Throws:
- IOException
 
- 
writeMapEndDescription copied from class:EncoderCall this method to terminate the inner-most, currently-opened map. SeeEncoder.writeArrayStart()for more details.- Specified by:
- writeMapEndin class- Encoder
- Throws:
- IOException
 
- 
writeIndexDescription copied from class:EncoderCall this method to write the tag of a union. As an example of usage, let's say you want to write a union, whose second branch is a record consisting of an Long field and a Boolean field. Your code would look something like this:out.writeIndex(1); out.writeLong(record.longField); out.writeBoolean(record.boolField); - Specified by:
- writeIndexin class- Encoder
- Throws:
- IOException
 
- 
writeZeroWrite a zero byte to the underlying output.- Throws:
- IOException
 
- 
bytesBufferedpublic abstract int bytesBuffered()Returns the number of bytes currently buffered by this encoder. If this Encoder does not buffer, this will always return zero. CallFlushable.flush()to empty the buffer to the underlying output.
 
-