| Modifier and Type | Field and Description | 
|---|---|
| protected int | binaryBlockSize | 
| protected int | binaryBufferSize | 
| Constructor and Description | 
|---|
| EncoderFactory() | 
| Modifier and Type | Method and Description | 
|---|---|
| BinaryEncoder | binaryEncoder(OutputStream out,
             BinaryEncoder reuse)Creates or reinitializes a  BinaryEncoderwith the OutputStream
 provided as the destination for written data. | 
| BinaryEncoder | blockingBinaryEncoder(OutputStream out,
                     BinaryEncoder reuse)Creates or reinitializes a  BinaryEncoderwith the OutputStream
 provided as the destination for written data. | 
| EncoderFactory | configureBlockSize(int size)Configures this factory to construct blocking BinaryEncoders with the
 specified block buffer size. | 
| EncoderFactory | configureBufferSize(int size)Configures this factory to use the specified buffer size when creating
 Encoder instances that buffer their output. | 
| BinaryEncoder | directBinaryEncoder(OutputStream out,
                   BinaryEncoder reuse)Creates or reinitializes a  BinaryEncoderwith the OutputStream
 provided as the destination for written data. | 
| static EncoderFactory | get()Returns an immutable static DecoderFactory with default configuration. | 
| int | getBlockSize()Returns this factory's configured default block buffer size. | 
| int | getBufferSize()Returns this factory's configured default buffer size. | 
| JsonEncoder | jsonEncoder(Schema schema,
           OutputStream out)Creates a  JsonEncoderusing the OutputStream provided for writing
 data conforming to the Schema provided. | 
| JsonEncoder | jsonEncoder(Schema schema,
           OutputStream out,
           boolean pretty)Creates a  JsonEncoderusing the OutputStream provided for writing
 data conforming to the Schema provided with optional pretty printing. | 
| ValidatingEncoder | validatingEncoder(Schema schema,
                 Encoder encoder)Creates a  ValidatingEncoderthat wraps the Encoder provided. | 
protected int binaryBufferSize
protected int binaryBlockSize
public static EncoderFactory get()
public EncoderFactory configureBufferSize(int size)
size - The buffer size to configure new instances with. Valid values are
             in the range [32, 16*1024*1024]. Values outside this range are
             set to the nearest value in the range. Values less than 256 will
             limit performance but will consume less memory if the
             BinaryEncoder is short-lived, values greater than 8*1024 are not
             likely to improve performance but may be useful for the
             downstream OutputStream.
         EncoderFactory factory = new EncoderFactory().configureBufferSize(4096);
         binaryEncoder(OutputStream, BinaryEncoder)public int getBufferSize()
configureBufferSize(int), 
binaryEncoder(OutputStream, BinaryEncoder)public EncoderFactory configureBlockSize(int size)
size - The preferred block size for array blocking. Arrays larger than
             this size will be segmented into blocks according to the Avro
             spec. Valid values are in the range [64, 1024*1024*1024] Values
             outside this range are set to the nearest value in the range. The
             encoder will require at least this amount of memory.
         EncoderFactory factory = new EncoderFactory().configureBlockSize(8000);
         blockingBinaryEncoder(OutputStream, BinaryEncoder)public int getBlockSize()
BinaryEncoder instances created with
 #blockingBinaryEncoder(OutputStream, BinaryEncoder) will have block buffers
 of this size.
 configureBlockSize(int), 
blockingBinaryEncoder(OutputStream, BinaryEncoder)public BinaryEncoder binaryEncoder(OutputStream out, BinaryEncoder reuse)
BinaryEncoder with the OutputStream
 provided as the destination for written data. If reuse is provided, an
 attempt will be made to reconfigure reuse rather than construct a new
 instance, but this is not guaranteed, a new instance may be returned.
 
 The BinaryEncoder implementation returned may buffer its output. Data
 may not appear on the underlying OutputStream until Flushable.flush()
 is called. The buffer size is configured with
 configureBufferSize(int).
 
 If buffering is not desired, and lower performance is acceptable, use
 directBinaryEncoder(OutputStream, BinaryEncoder)
 
 BinaryEncoder instances returned by this method are not thread-safeout - The OutputStream to write to. Cannot be null.reuse - The BinaryEncoder to attempt to reuse given the factory
              configuration. A BinaryEncoder implementation may not be
              compatible with reuse, causing a new instance to be returned. If
              null, a new instance is returned.IOExceptionBufferedBinaryEncoder, 
Encoderpublic BinaryEncoder directBinaryEncoder(OutputStream out, BinaryEncoder reuse)
BinaryEncoder with the OutputStream
 provided as the destination for written data. If reuse is provided, an
 attempt will be made to reconfigure reuse rather than construct a new
 instance, but this is not guaranteed, a new instance may be returned.
 
 The BinaryEncoder implementation returned does not buffer its output,
 calling Flushable.flush() will simply cause the wrapped OutputStream to
 be flushed.
 
 Performance of unbuffered writes can be significantly slower than buffered
 writes. binaryEncoder(OutputStream, BinaryEncoder) returns
 BinaryEncoder instances that are tuned for performance but may buffer output.
 The unbuffered, 'direct' encoder may be desired when buffering semantics are
 problematic, or if the lifetime of the encoder is so short that the buffer
 would not be useful.
 
 BinaryEncoder instances returned by this method are not thread-safe.out - The OutputStream to initialize to. Cannot be null.reuse - The BinaryEncoder to attempt to reuse given the factory
              configuration. A BinaryEncoder implementation may not be
              compatible with reuse, causing a new instance to be returned. If
              null, a new instance is returned.DirectBinaryEncoder, 
Encoderpublic BinaryEncoder blockingBinaryEncoder(OutputStream out, BinaryEncoder reuse)
BinaryEncoder with the OutputStream
 provided as the destination for written data. If reuse is provided, an
 attempt will be made to reconfigure reuse rather than construct a new
 instance, but this is not guaranteed, a new instance may be returned.
 
 The BinaryEncoder implementation returned buffers its output, calling
 Flushable.flush() is required for output to appear on the underlying
 OutputStream.
 
 The returned BinaryEncoder implements the Avro binary encoding using blocks
 delimited with byte sizes for Arrays and Maps. This allows for some decoders
 to skip over large Arrays or Maps without decoding the contents, but adds
 some overhead. The default block size is configured with
 configureBlockSize(int)
 
 BinaryEncoder instances returned by this method are not thread-safe.out - The OutputStream to initialize to. Cannot be null.reuse - The BinaryEncoder to attempt to reuse given the factory
              configuration. A BinaryEncoder implementation may not be
              compatible with reuse, causing a new instance to be returned. If
              null, a new instance is returned.IOExceptionBlockingBinaryEncoder, 
Encoderpublic JsonEncoder jsonEncoder(Schema schema, OutputStream out) throws IOException
JsonEncoder using the OutputStream provided for writing
 data conforming to the Schema provided.
 
 JsonEncoder buffers its output. Data may not appear on the underlying
 OutputStream until Flushable.flush() is called.
 
 JsonEncoder is not thread-safe.schema - The Schema for data written to this JsonEncoder. Cannot be
               null.out - The OutputStream to write to. Cannot be null.IOExceptionpublic JsonEncoder jsonEncoder(Schema schema, OutputStream out, boolean pretty) throws IOException
JsonEncoder using the OutputStream provided for writing
 data conforming to the Schema provided with optional pretty printing.
 
 JsonEncoder buffers its output. Data may not appear on the underlying
 OutputStream until Flushable.flush() is called.
 
 JsonEncoder is not thread-safe.schema - The Schema for data written to this JsonEncoder. Cannot be
               null.out - The OutputStream to write to. Cannot be null.pretty - Pretty print encoding.IOExceptionpublic ValidatingEncoder validatingEncoder(Schema schema, Encoder encoder) throws IOException
ValidatingEncoder that wraps the Encoder provided. This
 ValidatingEncoder will ensure that operations against it conform to the
 schema provided.
 
 Many Encoders buffer their output. Data may not appear on the
 underlying output until Flushable.flush() is called.
 
 ValidatingEncoder is not thread-safe.schema - The Schema to validate operations against. Cannot be null.encoder - The Encoder to wrap. Cannot be be null.IOExceptionCopyright © 2009–2023 The Apache Software Foundation. All rights reserved.