Class XChars
- java.lang.Object
-
- one.microstream.chars.XChars
-
public final class XChars extends Object
Static util class with character operation algorithms missing in or significantly superior to those in JDK.
-
-
Constructor Summary
Constructors Constructor Description XChars()
-
Method Summary
Modifier and Type Method Description static char[]append(char[] string, char c)static char[]append(char[] a, char[] b)static char[]append(char c, char[] string)static VarStringappendArraySeperated(VarString vc, char separator, Object... elements)static VarStringappendArraySeperated(VarString vs, String separator, Object... elements)static booleanapplies(CharSequence chars, int startIndex, _charPredicate predicate)static booleanapplies(CharSequence chars, _charPredicate predicate)static VarStringassembleCautiously(VarString vs, Object object)Assembles the passed instance "cautiously" in the sense that only types recognizable viaXTypes.isValueType(Object)get assembled using theirObject.toString()method, while all others are assembled usingsystemString(Object)(which behaves identical to the actual implementation ofObject.toString()).static voidassembleNewLinedTabbed(VarString vs, CharSequence... elements)static StringasString(char c)This method does intentionally not use the pseudo-constructor naming pattern since it does not create new instances ofString.static StringasString(char... chars)static intcommonPrefixLength(char[] a, char[] b)static intcommonSubstringLength(char[] a, char[] b)static intcommonSuffixLength(char[] a, char[] b)static char[]concat(char[]... arrays)static Stringconcat(char separator, Object... parts)static booleancontains(char[] subject, int subjectOffset, int subjectLength, char[] sample, int sampleOffset, int sampleLength)static booleancontains(String[] strings, String subject)static StringconvertUnderscoresToCamelCase(String parameterName)static VarStringconvertUnderscoresToCamelCase(VarString vs, String s)static intcount(char[] haystack, int haystackOffset, int haystackCount, char needle)static intcount(char[] data, int dataOffset, int dataCount, char[] subject, int subjectOffset, int subjectCount)static StringcreateMedialCapitalsString(String... elements)static CharsetdefaultJvmCharset()Alias forCharset.defaultCharset(), which returns sometimes the one thing and sometimes another.static StringensureCharAtEnd(String s, char c)static booleanequals(char[] chars1, int offset1, char[] chars2, int offset2, int length)static booleanequals(String string, char[] chars, int offset)static StringescapeChar(char c)static VarStringescapeChar(VarString vc, char c)static booleanhasContent(CharSequence s)static booleanhasContent(String s)static inthashCode(char[] chars, int offset, int length)This method rebuilds theStringhashing algorithm as the JDK guys forgot as usual to make their stuff professionally modular.static booleanhasNoContent(CharSequence s)static booleanhasNoContent(String s)static intindexOf(char[] data, char c)static intindexOf(char[] data, int dataLength, char[] subject)static intindexOf(char[] source, int sourceCount, char[] target, int targetCount, int fromIndex)static intindexOf(char[] data, int offset, int length, char c)static intindexOf(char[] data, int dataOffset, int dataLength, char[] chars)static intindexOf(char[] source, int sourceOffset, int sourceCount, char[] target, int targetOffset, int targetCount, int fromIndex)static longinternalParse_longLiteral(char[] input, int offset, int length)Specialcase higher performance implementation of decimal integer literal parsing.static booleanintersects(char[] chars1, char[] chars2)Returnstrueif the two given character arrays have at least one character in common.static booleanisDigit(char c)static booleanisEmpty(CharSequence cs)static booleanisEqual(String s1, String s2)static booleanisEqualIgnoreCase(String s1, String s2)static booleanisNonWhitespace(char c)static booleanisWhitespace(char c)static voiditerate(char[] chars, int offset, int length, _charProcedure iterator)static voiditerate(char[] chars, _charProcedure iterator)static voiditerate(CharSequence chars, _charProcedure iterator)static voiditerate(String chars, _charProcedure iterator)static char[]longestCommonPrefix(char[] a, char[] b)static StringlongestCommonPrefix(String a, String b)static intlongestCommonPrefixLength(String a, String b)static char[]longestCommonSubstring(char[] a, char[] b)static StringlongestCommonSubstring(String a, String b)static intlongestCommonSubstringLength(String a, String b)static char[]longestCommonSuffix(char[] a, char[] b)static StringlongestCommonSuffix(String a, String b)static intlongestCommonSuffixLength(String a, String b)static StringlowerCaseFirstChar(String s)static intmaxCharCount_boolean()static intmaxCharCount_byte()static intmaxCharCount_char()static intmaxCharCount_double()static intmaxCharCount_float()static intmaxCharCount_int()static intmaxCharCount_long()static intmaxCharCount_short()static StringnonNullString(Object object)static <C extends CharSequence>
CnotEmpty(C charSequence)static StringpadLeft(String s, int totalLength)static StringpadLeft(String s, int totalLength, char paddingChar)static StringpadLeft0(String s, int totalLength)static StringpadRight(String s, int totalLength)static StringpadRight(String s, int totalLength, char paddingChar)static StringpadRight0(String s, int totalLength)static StringpadSpace(String s, int chars)static byteparse_byteDecimal(char[] input)static byteparse_byteDecimal(char[] input, int offset, int length)static doubleparse_double(char[] input, int offset, int length)static floatparse_float(char[] input, int offset, int length)static intparse_intLiteral(char[] input)static intparse_intLiteral(char[] input, int offset, int length)static longparse_longDecimal(char[] input)static longparse_longDecimal(char[] input, int offset, int length)static shortparse_shortDecimal(char[] input)static shortparse_shortDecimal(char[] input, int offset, int length)static charparseChar(String s)Parses the char escape sequence Strings "\n" etc.static int[]parseTo_intArray(String... intStrings)static Integer[]parseToIntegerArray(String... intStrings)static intput(boolean value, char[] target, int offset)static intput(byte value, char[] target, int offset)static intput(char[] value, char[] target, int offset)static intput(double value, char[] target, int offset)static intput(float value, char[] target, int offset)static intput(int value, char[] target, int offset)static intput(long value, char[] target, int offset)static intput(short value, char[] target, int offset)static intput(String s, char[] target, int offset)static intputFalse(char[] target, int offset)static intputHexDec(byte value, char[] target, int offset)static intputNull(char[] target, int offset)static intputTrue(char[] target, int offset)static charrandomReadable_char()static VarBytereadAllBytesFromInputStream(InputStream inputStream)static VarBytereadAllBytesFromInputStream(VarByte bytes, InputStream inputStream)static char[]readChars(String s)static StringreadStringFromInputStream(InputStream inputStream, Charset charset)static intreplaceFirst(char[] chars, int offset, int length, char sample, char replacement)static <C extends Consumer<String>>
CsplitAndTrimToStrings(char[] input, char separator, C collector)High-performance implementation of the very common case to split a character sequence by a single character and trim all elements.static <C extends Consumer<String>>
CsplitAndTrimToStrings(String input, char separator, C collector)High-performance implementation of the very common case to split a string by a single character and trim all elements.static CharsetstandardCharset()ReturnsStandardCharsets.UTF_8, because any other one out there is nonsense as a standard.static StringString(boolean value)static StringString(byte value)static StringString(byte[] chars)static StringString(byte[] chars, int offset, int length)static StringString(byte[] chars, int offset, int length, Charset charset)static StringString(byte[] chars, Charset charset)static StringString(char value)static StringString(char[] chars)static StringString(char[] chars, int offset, int length)static StringString(double value)static StringString(float value)static StringString(int value)static StringString(long value)static StringString(short value)static StringString(ByteBuffer chars)static StringString(ByteBuffer chars, int offset, int length)static StringString(ByteBuffer chars, int offset, int length, Charset charset)static StringString(ByteBuffer chars, Charset charset)static StringBufferStringBuffer(VarString vs)static StringBufferStringBuffer(VarString vs, int offset, int length)static StringBuilderStringBuilder(VarString vs)static StringBuilderStringBuilder(VarString vs, int offset, int length)static char[]substring(char[] string, int offset, int bound)static StringsystemString(Object instance)Utility method that replicates the JVM's intrinsic system string as defined inObject.toString().static intto_int(char digit)static char[][]toArrays(XGettingSequence<String> strings)static char[]toCharArray(CharSequence c)static char[]toCharArray(StringBuffer asb)static char[]toCharArray(StringBuilder asb)static chartoHexadecimal(int b)static StringtoSingleLine(String multiLineString, String lineBreakReplacement)static Stringtrim(String s)CallsString.trim()on a non-null argument, returnsnullotherwise.static StringtrimEmptyToNull(String s)static StringtrimToString(char[] input, int lowerOffset, int length)Creates aStringinstance with trimmed content directly from a character sequence without unnecessary intermediate instances.static byteuncheckedParse_byteDecimal(char[] input, int offset, int length)static intuncheckedParse_intLiteral(char[] input, int offset, int length)static longuncheckedParse_longLiteral(char[] input, int offset, int length)static shortuncheckedParse_shortDecimal(char[] input, int offset, int length)static StringupperCaseFirstChar(String s)Ensures that the first character of the passedStringis in upper case.static Charsetutf8()It's UTF-8!static voidvalidateIndex(char[] chars, int index)static voidvalidateRange(char[] chars, int offset, int length)static StringvalueString(Object value)Returnsvalue.toString()if the passed value is not null, otherwise null.
-
-
-
Method Detail
-
maxCharCount_byte
public static final int maxCharCount_byte()
-
maxCharCount_boolean
public static final int maxCharCount_boolean()
-
maxCharCount_short
public static final int maxCharCount_short()
-
maxCharCount_char
public static final int maxCharCount_char()
-
maxCharCount_int
public static final int maxCharCount_int()
-
maxCharCount_float
public static final int maxCharCount_float()
-
maxCharCount_long
public static final int maxCharCount_long()
-
maxCharCount_double
public static final int maxCharCount_double()
-
isWhitespace
public static final boolean isWhitespace(char c)
-
isNonWhitespace
public static final boolean isNonWhitespace(char c)
-
utf8
public static final Charset utf8()
It's UTF-8!- Returns:
StandardCharsets.UTF_8
-
standardCharset
public static final Charset standardCharset()
ReturnsStandardCharsets.UTF_8, because any other one out there is nonsense as a standard.- Returns:
java.nio.charset.Charset.forName("UTF-8").
-
defaultJvmCharset
public static final Charset defaultJvmCharset()
Alias forCharset.defaultCharset(), which returns sometimes the one thing and sometimes another. It is strongly advised to use a reliableCharsetquerying method, likeutf8(), which also is the only reasonable choice for thestandardCharset().- Returns:
Charset.defaultCharset()
-
validateIndex
public static final void validateIndex(char[] chars, int index)
-
validateRange
public static final void validateRange(char[] chars, int offset, int length)
-
equals
public static final boolean equals(String string, char[] chars, int offset)
-
equals
public static final boolean equals(char[] chars1, int offset1, char[] chars2, int offset2, int length)
-
toHexadecimal
public static final char toHexadecimal(int b) throws IllegalArgumentException- Throws:
IllegalArgumentException
-
indexOf
public static final int indexOf(char[] data, char c)
-
indexOf
public static final int indexOf(char[] data, int offset, int length, char c)
-
indexOf
public static final int indexOf(char[] source, int sourceOffset, int sourceCount, char[] target, int targetOffset, int targetCount, int fromIndex)
-
readAllBytesFromInputStream
public static final VarByte readAllBytesFromInputStream(VarByte bytes, InputStream inputStream) throws IOException
- Throws:
IOException
-
readAllBytesFromInputStream
public static final VarByte readAllBytesFromInputStream(InputStream inputStream) throws IOException
- Throws:
IOException
-
readStringFromInputStream
public static final String readStringFromInputStream(InputStream inputStream, Charset charset) throws IOException
- Throws:
IOException
-
indexOf
public static final int indexOf(char[] data, int dataLength, char[] subject)
-
indexOf
public static final int indexOf(char[] data, int dataOffset, int dataLength, char[] chars)
-
indexOf
public static final int indexOf(char[] source, int sourceCount, char[] target, int targetCount, int fromIndex)
-
replaceFirst
public static final int replaceFirst(char[] chars, int offset, int length, char sample, char replacement)
-
count
public static final int count(char[] haystack, int haystackOffset, int haystackCount, char needle)
-
count
public static final int count(char[] data, int dataOffset, int dataCount, char[] subject, int subjectOffset, int subjectCount)
-
hasContent
public static final boolean hasContent(CharSequence s)
-
hasNoContent
public static final boolean hasNoContent(CharSequence s)
-
hasContent
public static final boolean hasContent(String s)
-
hasNoContent
public static final boolean hasNoContent(String s)
-
asString
public static final String asString(char c)
This method does intentionally not use the pseudo-constructor naming pattern since it does not create new instances ofString. Instead, it returns a constant instance of an intrinsic look-up table.
-
asString
public static final String asString(char... chars)
-
upperCaseFirstChar
public static final String upperCaseFirstChar(String s)
Ensures that the first character of the passedStringis in upper case.If the passed
Stringisnull, has a length of 0 or already has an upper case first character, it is returned. Otherwise, the first character of the passedStringis transformed to upper case and concatenated with the rest of the passedStringinto a newStringinstance.- Parameters:
s- theStringfor which the first character shall be ensured to be upper case.- Returns:
- a string equalling s with its first character being guaranteed to be upper case.
-
concat
public static final char[] concat(char[]... arrays)
-
appendArraySeperated
public static final VarString appendArraySeperated(VarString vs, String separator, Object... elements)
-
appendArraySeperated
public static final VarString appendArraySeperated(VarString vc, char separator, Object... elements)
-
toCharArray
public static final char[] toCharArray(CharSequence c)
-
toCharArray
public static final char[] toCharArray(StringBuilder asb)
-
toCharArray
public static final char[] toCharArray(StringBuffer asb)
-
intersects
public static final boolean intersects(char[] chars1, char[] chars2)Returnstrueif the two given character arrays have at least one character in common.- Parameters:
chars1-chars2-- Returns:
trueif the two given character arrays intersect each other.
-
append
public static final char[] append(char c, char[] string)
-
append
public static final char[] append(char[] string, char c)
-
append
public static final char[] append(char[] a, char[] b)
-
longestCommonSubstringLength
public static final int longestCommonSubstringLength(String a, String b)
-
commonSubstringLength
public static final int commonSubstringLength(char[] a, char[] b)
-
longestCommonSubstring
public static final char[] longestCommonSubstring(char[] a, char[] b)
-
substring
public static final char[] substring(char[] string, int offset, int bound)
-
convertUnderscoresToCamelCase
public static final String convertUnderscoresToCamelCase(String parameterName)
-
convertUnderscoresToCamelCase
public static final VarString convertUnderscoresToCamelCase(VarString vs, String s)
-
commonPrefixLength
public static final int commonPrefixLength(char[] a, char[] b)
-
commonSuffixLength
public static final int commonSuffixLength(char[] a, char[] b)
-
longestCommonSuffix
public static final char[] longestCommonSuffix(char[] a, char[] b)
-
longestCommonPrefix
public static final char[] longestCommonPrefix(char[] a, char[] b)
-
parseChar
public static final char parseChar(String s)
Parses the char escape sequence Strings "\n" etc. (wihtout the "") to the singel char value represented by those strings.- Parameters:
s-
-
escapeChar
public static final String escapeChar(char c)
-
createMedialCapitalsString
public static final String createMedialCapitalsString(String... elements)
-
toSingleLine
public static final String toSingleLine(String multiLineString, String lineBreakReplacement)
-
notEmpty
public static final <C extends CharSequence> C notEmpty(C charSequence)
-
isEmpty
public static final boolean isEmpty(CharSequence cs)
-
iterate
public static final void iterate(CharSequence chars, _charProcedure iterator)
-
iterate
public static final void iterate(String chars, _charProcedure iterator)
-
iterate
public static final void iterate(char[] chars, _charProcedure iterator)
-
iterate
public static final void iterate(char[] chars, int offset, int length, _charProcedure iterator)
-
put
public static final int put(byte value, char[] target, int offset)
-
putHexDec
public static final int putHexDec(byte value, char[] target, int offset)
-
put
public static final int put(boolean value, char[] target, int offset)
-
put
public static final int put(short value, char[] target, int offset)
-
put
public static final int put(int value, char[] target, int offset)
-
put
public static final int put(float value, char[] target, int offset)
-
put
public static final int put(long value, char[] target, int offset)
-
put
public static final int put(double value, char[] target, int offset)
-
put
public static final int put(String s, char[] target, int offset)
-
put
public static final int put(char[] value, char[] target, int offset)
-
putNull
public static final int putNull(char[] target, int offset)
-
putTrue
public static final int putTrue(char[] target, int offset)
-
putFalse
public static final int putFalse(char[] target, int offset)
-
String
public static final String String(byte value)
-
String
public static final String String(boolean value)
-
String
public static final String String(short value)
-
String
public static final String String(char value)
-
String
public static final String String(int value)
-
String
public static final String String(float value)
-
String
public static final String String(long value)
-
String
public static final String String(double value)
-
String
public static final String String(char[] chars)
-
String
public static final String String(char[] chars, int offset, int length)
-
String
public static final String String(byte[] chars)
-
String
public static final String String(byte[] chars, int offset, int length)
-
String
public static final String String(ByteBuffer chars)
-
String
public static final String String(ByteBuffer chars, Charset charset)
-
String
public static final String String(ByteBuffer chars, int offset, int length)
-
String
public static final String String(ByteBuffer chars, int offset, int length, Charset charset)
-
StringBuilder
public static final StringBuilder StringBuilder(VarString vs)
-
StringBuilder
public static final StringBuilder StringBuilder(VarString vs, int offset, int length)
-
StringBuffer
public static final StringBuffer StringBuffer(VarString vs)
-
StringBuffer
public static final StringBuffer StringBuffer(VarString vs, int offset, int length)
-
readChars
public static final char[] readChars(String s)
-
hashCode
public static final int hashCode(char[] chars, int offset, int length)This method rebuilds theStringhashing algorithm as the JDK guys forgot as usual to make their stuff professionally modular.Returns a hash code for the passed character range. The hash code is computed as
usings[0]*31^(n - 1) + s[1]*31^(n-2) + ... + s[n - 1]
intarithmetic, wheres[i]is the ith character counted from the given offset,nis the length and^indicates exponentiation. The hash value of an empty range is zero.- Returns:
- a hash code value for this object.
- See Also:
String.hashCode()
-
splitAndTrimToStrings
public static final <C extends Consumer<String>> C splitAndTrimToStrings(String input, char separator, C collector)
High-performance implementation of the very common case to split a string by a single character and trim all elements.- Parameters:
input-separator-- See Also:
trimToString(char[],int,int)
-
splitAndTrimToStrings
public static final <C extends Consumer<String>> C splitAndTrimToStrings(char[] input, char separator, C collector)
High-performance implementation of the very common case to split a character sequence by a single character and trim all elements.- Parameters:
input-separator-- See Also:
trimToString(char[],int,int)
-
trimToString
public static final String trimToString(char[] input, int lowerOffset, int length)
Creates aStringinstance with trimmed content directly from a character sequence without unnecessary intermediate instances.- Parameters:
input-lowerOffset-length-
-
trim
public static String trim(String s)
CallsString.trim()on a non-null argument, returnsnullotherwise. (this is nothing but a staticString.trim())
-
parseTo_intArray
public static final int[] parseTo_intArray(String... intStrings)
-
assembleNewLinedTabbed
public static final void assembleNewLinedTabbed(VarString vs, CharSequence... elements)
-
parse_byteDecimal
public static final byte parse_byteDecimal(char[] input)
-
parse_shortDecimal
public static final short parse_shortDecimal(char[] input)
-
parse_intLiteral
public static final int parse_intLiteral(char[] input)
-
parse_longDecimal
public static final long parse_longDecimal(char[] input)
-
parse_byteDecimal
public static final byte parse_byteDecimal(char[] input, int offset, int length)
-
parse_shortDecimal
public static final short parse_shortDecimal(char[] input, int offset, int length)
-
parse_intLiteral
public static final int parse_intLiteral(char[] input, int offset, int length)
-
parse_longDecimal
public static final long parse_longDecimal(char[] input, int offset, int length)
-
parse_float
public static final float parse_float(char[] input, int offset, int length)
-
parse_double
public static final double parse_double(char[] input, int offset, int length)
-
uncheckedParse_byteDecimal
public static final byte uncheckedParse_byteDecimal(char[] input, int offset, int length)
-
uncheckedParse_shortDecimal
public static final short uncheckedParse_shortDecimal(char[] input, int offset, int length)
-
uncheckedParse_intLiteral
public static final int uncheckedParse_intLiteral(char[] input, int offset, int length)
-
uncheckedParse_longLiteral
public static final long uncheckedParse_longLiteral(char[] input, int offset, int length)
-
internalParse_longLiteral
public static final long internalParse_longLiteral(char[] input, int offset, int length)Specialcase higher performance implementation of decimal integer literal parsing. Because as usual, the JDK implementation strategies are not acceptable when dealing with non-trivial amounts of data. Properly executed performance tests (large loop sizes, averages, nanosecond precision, etc.) showed that this algorithms is more than twice as fast as the one used in JDK (average of ~33µs vs ~75µs for long literals on same machine with measuring overhead of ~1.5µs)- Parameters:
input-offset-length-
-
to_int
public static final int to_int(char digit)
-
toArrays
public static final char[][] toArrays(XGettingSequence<String> strings)
-
contains
public static final boolean contains(char[] subject, int subjectOffset, int subjectLength, char[] sample, int sampleOffset, int sampleLength)
-
systemString
public static String systemString(Object instance)
Utility method that replicates the JVM's intrinsic system string as defined inObject.toString(). (It's funny how much functionality is missing in the JDK API).- Parameters:
instance- the instance whose system string shall be generated.- Returns:
- the system string for the passed instance.
-
valueString
public static String valueString(Object value)
Returnsvalue.toString()if the passed value is not null, otherwise null.Note that this is a different behavior than
String.valueOf(Object)has, as the latter returns the string"null"for a passed null reference. The latter is merely an output helper method, albeit clumsily named and placed as if it were a general utility method. THIS method here is the far more useful general utility method.The behavior of this method is needed for example for converting values in a generic data structure (e.g. a Object[] array) to string values but have the actual values, including null(information about a missing value), maintained.
- Parameters:
value- the value to be projected to its string representation if not null.- Returns:
- a string representation of an actual passed value or a transient null.
- See Also:
Object.toString(),String.valueOf(Object)
-
assembleCautiously
public static final VarString assembleCautiously(VarString vs, Object object)
Assembles the passed instance "cautiously" in the sense that only types recognizable viaXTypes.isValueType(Object)get assembled using theirObject.toString()method, while all others are assembled usingsystemString(Object)(which behaves identical to the actual implementation ofObject.toString()).- Parameters:
vs- theVarStringinstance to hold the assembled string.object- the instance to be assembled "cautiously" as described above.- Returns:
- the passed vs instance (method-chaining viable).
- See Also:
VarString.add(Object,java.util.function.BiConsumer),XTypes.isValueType(Object),Object.toString(),systemString(Object)
-
applies
public static final boolean applies(CharSequence chars, _charPredicate predicate)
-
applies
public static final boolean applies(CharSequence chars, int startIndex, _charPredicate predicate)
-
isDigit
public static boolean isDigit(char c)
-
randomReadable_char
public static char randomReadable_char()
-
-