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
BinaryEncoder with the OutputStream
provided as the destination for written data. |
BinaryEncoder |
blockingBinaryEncoder(OutputStream out,
BinaryEncoder reuse)
Creates or reinitializes a
BinaryEncoder with 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
BinaryEncoder with 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
JsonEncoder using the OutputStream provided for writing
data conforming to the Schema provided. |
JsonEncoder |
jsonEncoder(Schema schema,
OutputStream out,
boolean pretty)
Creates a
JsonEncoder using the OutputStream provided for writing
data conforming to the Schema provided with optional pretty printing. |
ValidatingEncoder |
validatingEncoder(Schema schema,
Encoder encoder)
Creates a
ValidatingEncoder that 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)
.
directBinaryEncoder(OutputStream, BinaryEncoder)
BinaryEncoder
instances returned by this method are not thread-safe
out
- 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.IOException
BufferedBinaryEncoder
,
Encoder
public 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
,
Encoder
public 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.IOException
BlockingBinaryEncoder
,
Encoder
public 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.IOException
public 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.IOException
public 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 Encoder
s 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.IOException
Copyright © 2009–2022 The Apache Software Foundation. All rights reserved.