com.github.powerlibraries.io.helper.byteout.BAObjectOutputStream Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of iopower Show documentation
Show all versions of iopower Show documentation
Power Libraries is a small project to collect some repeatedly needed or otherwise useful Java 8 classes in a collection of tiny libraries.
IO Power is the first and really tiny library of the Power Libraries. It contains some simple helper method for opening Input- and Outputstreams. The main purpose of IO Power is to make opening streams, readers and writers less cluttered and simple to understand.
package com.github.powerlibraries.io.helper.byteout;
import java.io.ByteArrayOutputStream;
import java.io.DataOutputStream;
import java.io.IOException;
import java.io.ObjectOutputStream;
import java.io.OutputStream;
/**
* This class extends an {@link ObjectOutputStream} with the ability to directly access an underlying
* {@link ByteArrayOutputStream}.
*
* @see DataOutputStream
* @see ByteArrayWrapper
* @author Manuel Hegner
*/
public class BAObjectOutputStream extends ObjectOutputStream implements ByteArrayWrapper {
private ByteArrayOutputStream underlyingOutput;
public BAObjectOutputStream(OutputStream outputStream, ByteArrayOutputStream underlyingOutput) throws IOException {
super(outputStream);
this.underlyingOutput=underlyingOutput;
}
/**
* Converts the buffer's contents into a string decoding bytes using the
* platform's default character set. The length of the new String
* is a function of the character set, and hence may not be equal to the
* size of the buffer.
*
* This method always replaces malformed-input and unmappable-character
* sequences with the default replacement string for the platform's
* default character set. The {@linkplain java.nio.charset.CharsetDecoder}
* class should be used when more control over the decoding process is
* required.
*
* @return String decoded from the buffer's contents.
*/
@Override
public String toString() {
return getUnderlyingOutput().toString();
}
@Override
public ByteArrayOutputStream getUnderlyingOutput() {
return underlyingOutput;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy