net.sf.ehcache.util
Class MemoryEfficientByteArrayOutputStream
java.lang.Object
   java.io.OutputStream
java.io.OutputStream
       java.io.ByteArrayOutputStream
java.io.ByteArrayOutputStream
           net.sf.ehcache.util.MemoryEfficientByteArrayOutputStream
net.sf.ehcache.util.MemoryEfficientByteArrayOutputStream
- All Implemented Interfaces: 
- Closeable, Flushable
- public final class MemoryEfficientByteArrayOutputStream 
- extends ByteArrayOutputStream
This class is designed to minimise the number of System.arraycopy(); methods
 required to complete.
 ByteArrayOutputStream in the JDK is tuned for a wide variety of purposes. This sub-class
 starts with an initial size which is a closer match for ehcache usage.
- Version:
- $Id$
- Author:
- Greg Luck
 
 
 
 
 
 
 
MemoryEfficientByteArrayOutputStream
public MemoryEfficientByteArrayOutputStream(int size)
- Creates a new byte array output stream, with a buffer capacity of
 the specified size, in bytes.
 
- Parameters:
- size- the initial size.
 
getBytes
public byte[] getBytes()
- Gets the bytes.
 
- 
- Returns:
- the underlying byte[], or a copy if the byte[] is oversized
 
serialize
public static MemoryEfficientByteArrayOutputStream serialize(Serializable serializable,
                                                             int estimatedPayloadSize)
                                                      throws IOException
- Factory method
 
- 
- Parameters:
- serializable- any Object that implements Serializable
- estimatedPayloadSize- how many bytes is expected to be in the Serialized representation
- Returns:
- a ByteArrayOutputStream with a Serialized object in it
- Throws:
- IOException- if something goes wrong with the Serialization
 
serialize
public static MemoryEfficientByteArrayOutputStream serialize(Serializable serializable)
                                                      throws IOException
- Factory method. This method optimises memory by trying to make a better guess than the Java default
 of 32 bytes by assuming the starting point for the serialized size will be what it was last time
 this method was called.
 
- 
- Parameters:
- serializable- any Object that implements Serializable
- Returns:
- a ByteArrayOutputStream with a Serialized object in it
- Throws:
- IOException- if something goes wrong with the Serialization
 
Copyright 2001-2016, Terracotta, Inc.