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

jodd.util.StringBand Maven / Gradle / Ivy

// Copyright (c) 2003-present, Jodd Team (http://jodd.org)
// All rights reserved.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are met:
//
// 1. Redistributions of source code must retain the above copyright notice,
// this list of conditions and the following disclaimer.
//
// 2. Redistributions in binary form must reproduce the above copyright
// notice, this list of conditions and the following disclaimer in the
// documentation and/or other materials provided with the distribution.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
// POSSIBILITY OF SUCH DAMAGE.

package jodd.util;

/**
 * StringBand is a faster alternative to StringBuilder.
 * Instead of adding strings, they are stored in an internal array. Only at the
 * end of concatenation, when toString() is invoked, strings are
 * joined together in a very fast manner.
 * 

* To make StringBand even faster, predict the number of joined * strings (and not the final string size)! */ public class StringBand { private static final int DEFAULT_ARRAY_CAPACITY = 16; private String[] array; private int index; private int length; /** * Creates an empty StringBand. */ public StringBand() { array = new String[DEFAULT_ARRAY_CAPACITY]; } /** * Creates an empty StringBand with provided capacity. * Capacity refers to internal string array (i.e. number of * joins) and not the total string size. */ public StringBand(final int initialCapacity) { array = new String[initialCapacity]; } /** * Creates StringBand with provided content. */ public StringBand(final String s) { this(); array[0] = s; index = 1; length = s.length(); } public StringBand(final Object o) { this(String.valueOf(o)); } // ---------------------------------------------------------------- append /** * Appends boolean value. */ public StringBand append(final boolean b) { return append(b ? StringPool.TRUE : StringPool.FALSE); } /** * Appends double value. */ public StringBand append(final double d) { return append(Double.toString(d)); } /** * Appends float value. */ public StringBand append(final float f) { return append(Float.toString(f)); } /** * Appends int value. */ public StringBand append(final int i) { return append(Integer.toString(i)); } /** * Appends long value. */ public StringBand append(final long l) { return append(Long.toString(l)); } /** * Appends short value. */ public StringBand append(final short s) { return append(Short.toString(s)); } /** * Appends a character. This is not efficient * as in StringBuilder, since new string is created. */ public StringBand append(final char c) { return append(String.valueOf(c)); } /** * Appends byte value. */ public StringBand append(final byte b) { return append(Byte.toString(b)); } /** * Appends string representation of an object. * If null, the 'null' string * will be appended. */ public StringBand append(final Object obj) { return append(String.valueOf(obj)); } /** * Appends a string. */ public StringBand append(String s) { if (s == null) { s = StringPool.NULL; } if (index >= array.length) { expandCapacity(); } array[index++] = s; length += s.length(); return this; } // ---------------------------------------------------------------- size /** * Returns array capacity. */ public int capacity() { return array.length; } /** * Returns total string length. */ public int length() { return length; } /** * Returns current index of string array. */ public int index() { return index; } /** * Specifies the new index. */ public void setIndex(final int newIndex) { if (newIndex < 0) { throw new ArrayIndexOutOfBoundsException(newIndex); } if (newIndex > array.length) { String[] newArray = new String[newIndex]; System.arraycopy(array, 0, newArray, 0, index); array = newArray; } if (newIndex > index) { for (int i = index; i < newIndex; i++) { array[i] = StringPool.EMPTY; } } else if (newIndex < index) { for (int i = newIndex; i < index; i++) { array[i] = null; } } index = newIndex; length = calculateLength(); } // ---------------------------------------------------------------- values /** * Returns char at given position. * This method is not fast as it calculates * the right string array element and the offset! */ public char charAt(final int pos) { int len = 0; for (int i = 0; i < index; i++) { int newlen = len + array[i].length(); if (pos < newlen) { return array[i].charAt(pos - len); } len = newlen; } throw new IllegalArgumentException("Invalid char index"); } /** * Returns string at given position. */ public String stringAt(final int index) { if (index >= this.index) { throw new ArrayIndexOutOfBoundsException(); } return array[index]; } /** * Joins together all strings into one. */ @Override public String toString() { // special cases switch (index) { case 0: return StringPool.EMPTY; case 1: return array[0]; case 2: return array[0] + array[1]; } // join strings char[] destination = new char[length]; int start = 0; for (int i = 0; i < index; i++) { String s = array[i]; int len = s.length(); s.getChars(0, len, destination, start); start += len; } return new String(destination); } // ---------------------------------------------------------------- utils /** * Expands internal string array by multiplying its size by 2. */ protected void expandCapacity() { String[] newArray = new String[array.length << 1]; System.arraycopy(array, 0, newArray, 0, index); array = newArray; } /** * Calculates string length. */ protected int calculateLength() { int len = 0; for (int i = 0; i < index; i++) { len += array[i].length(); } return len; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy