All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.landawn.abacus.util.ByteArrayOutputStream Maven / Gradle / Ivy

Go to download

A general programming library in Java/Android. It's easy to learn and simple to use with concise and powerful APIs.

There is a newer version: 5.3.16
Show newest version
/*
 * Copyright (C) 2015 HaiYang Li
 *
 * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except
 * in compliance with the License. You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software distributed under the License
 * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
 * or implied. See the License for the specific language governing permissions and limitations under
 * the License.
 */

package com.landawn.abacus.util;

import java.io.IOException;
import java.io.OutputStream;
import java.io.UnsupportedEncodingException;
import java.nio.charset.Charset;
import java.util.Arrays;

/**
 *
 * @author Haiyang Li
 * @since 0.8
 */
public final class ByteArrayOutputStream extends OutputStream {

    protected byte[] buf;

    protected int count;

    public ByteArrayOutputStream() {
        this(32);
    }

    public ByteArrayOutputStream(int size) {
        if (size < 0) {
            throw new IllegalArgumentException("Negative initial size: " + size);
        }

        buf = new byte[size];
    }

    /**
     *
     * @param b
     */
    @Override
    public void write(int b) {
        ensureCapacity(count + 1);
        buf[count] = (byte) b;
        count += 1;
    }

    /**
     *
     * @param b
     * @param off
     * @param len
     */
    @Override
    public void write(byte[] b, int off, int len) {
        if ((off < 0) || (off > b.length) || (len < 0) || (((off + len) - b.length) > 0)) {
            throw new IndexOutOfBoundsException();
        }

        ensureCapacity(count + len);
        N.copy(b, off, buf, count, len);
        count += len;
    }

    /**
     *
     * @param b
     */
    public void write(byte b) {
        ensureCapacity(count + 1);
        buf[count] = b;
        count += 1;
    }

    /**
     *
     * @param out
     * @throws IOException Signals that an I/O exception has occurred.
     */
    public void writeTo(OutputStream out) throws IOException {
        out.write(buf, 0, count);
    }

    public int capacity() {
        return buf == null ? 0 : buf.length;
    }

    public byte[] array() {
        return buf;
    }

    public int size() {
        return count;
    }

    /**
     * Reset.
     */
    public void reset() {
        count = 0;
    }

    /**
     * To byte array.
     *
     * @return
     */
    public byte[] toByteArray() {
        return Arrays.copyOf(buf, count);
    }

    @Override
    public String toString() {
        return new String(buf, 0, count);
    }

    /**
     *
     * @param charset
     * @return
     * @throws UnsupportedEncodingException the unsupported encoding exception
     */
    public String toString(Charset charset) throws UnsupportedEncodingException {
        return new String(buf, 0, count, charset);
    }

    /**
     *
     * @throws IOException Signals that an I/O exception has occurred.
     */
    @Override
    public void close() throws IOException {
        // Do nothing.
    }

    private void ensureCapacity(final int minCapacity) {
        if (minCapacity > N.MAX_ARRAY_SIZE || minCapacity < 0) {
            throw new OutOfMemoryError();
        }

        if ((minCapacity - buf.length) > 0) {
            int newCapacity = (int) (buf.length * 1.75);

            if (newCapacity < 0 || newCapacity > N.MAX_ARRAY_SIZE) {
                newCapacity = N.MAX_ARRAY_SIZE;
            }

            if (newCapacity < minCapacity) {
                newCapacity = minCapacity;
            }

            buf = Arrays.copyOf(buf, newCapacity);
        }
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy