|
|||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||
java.lang.Objectjava.lang.StringBuffer
public final class StringBuffer
StringBuffer represents a changeable String.
It provides the operations required to modify the
StringBuffer, including insert, replace, delete, append,
and reverse. It is thread-safe; meaning that all modifications to a buffer
are in synchronized methods.
StringBuffers are variable-length in nature, so even if
you initialize them to a certain size, they can still grow larger than
that. Capacity indicates the number of characters the
StringBuffer can have in it before it has to grow (growing
the char array is an expensive operation involving new).
Incidentally, compilers often implement the String operator "+"
by using a StringBuffer operation:
a + b
is the same as
new StringBuffer().append(a).append(b).toString().
Classpath's StringBuffer is capable of sharing memory with Strings for efficiency. This will help when a StringBuffer is converted to a String and the StringBuffer is not changed after that (quite common when performing string concatenation).
String| Constructor Summary | |
|---|---|
StringBuffer()
Create a new StringBuffer with default capacity 16. |
|
StringBuffer(int capacity)
Create an empty StringBuffer with the specified initial
capacity. |
|
StringBuffer(String str)
Create a new StringBuffer with the characters in the
specified String. |
|
| Method Summary | |
|---|---|
StringBuffer |
append(boolean bool)
Append the String value of the argument to this
StringBuffer. |
StringBuffer |
append(char ch)
Append the char to this StringBuffer. |
StringBuffer |
append(char[] data)
Append the char array to this StringBuffer. |
StringBuffer |
append(char[] data,
int offset,
int count)
Append part of the char array to this
StringBuffer. |
StringBuffer |
append(double dnum)
Append the String value of the argument to this
StringBuffer. |
StringBuffer |
append(float fnum)
Append the String value of the argument to this
StringBuffer. |
StringBuffer |
append(int inum)
Append the String value of the argument to this
StringBuffer. |
StringBuffer |
append(long lnum)
Append the String value of the argument to this
StringBuffer. |
StringBuffer |
append(Object obj)
Append the String value of the argument to this
StringBuffer. |
StringBuffer |
append(String str)
Append the String to this StringBuffer. |
StringBuffer |
append(StringBuffer stringBuffer)
Append the StringBuffer value of the argument to this
StringBuffer. |
int |
capacity()
Get the total number of characters this StringBuffer can
support before it must be grown. |
char |
charAt(int index)
Get the character at the specified index. |
StringBuffer |
delete(int start,
int end)
Delete characters from this StringBuffer. |
StringBuffer |
deleteCharAt(int index)
Delete a character from this StringBuffer. |
void |
ensureCapacity(int minimumCapacity)
Increase the capacity of this StringBuffer. |
void |
getChars(int srcOffset,
int srcEnd,
char[] dst,
int dstOffset)
Get the specified array of characters. |
int |
indexOf(String str)
Finds the first instance of a substring in this StringBuffer. |
int |
indexOf(String str,
int fromIndex)
Finds the first instance of a String in this StringBuffer, starting at a given index. |
StringBuffer |
insert(int offset,
boolean bool)
Insert the String value of the argument into this
StringBuffer. |
StringBuffer |
insert(int offset,
char ch)
Insert the char argument into this StringBuffer. |
StringBuffer |
insert(int offset,
char[] data)
Insert the char[] argument into this
StringBuffer. |
StringBuffer |
insert(int offset,
char[] str,
int str_offset,
int len)
Insert a subarray of the char[] argument into this
StringBuffer. |
StringBuffer |
insert(int offset,
double dnum)
Insert the String value of the argument into this
StringBuffer. |
StringBuffer |
insert(int offset,
float fnum)
Insert the String value of the argument into this
StringBuffer. |
StringBuffer |
insert(int offset,
int inum)
Insert the String value of the argument into this
StringBuffer. |
StringBuffer |
insert(int offset,
long lnum)
Insert the String value of the argument into this
StringBuffer. |
StringBuffer |
insert(int offset,
Object obj)
Insert the String value of the argument into this
StringBuffer. |
StringBuffer |
insert(int offset,
String str)
Insert the String argument into this
StringBuffer. |
int |
lastIndexOf(String str)
Finds the last instance of a substring in this StringBuffer. |
int |
lastIndexOf(String str,
int fromIndex)
Finds the last instance of a String in this StringBuffer, starting at a given index. |
int |
length()
Get the length of the String this StringBuffer
would create. |
StringBuffer |
replace(int start,
int end,
String str)
Replace characters between index start (inclusive) and
end (exclusive) with str. |
StringBuffer |
reverse()
Reverse the characters in this StringBuffer. |
void |
setCharAt(int index,
char ch)
Set the character at the specified index. |
void |
setLength(int newLength)
Set the length of this StringBuffer. |
String |
substring(int beginIndex)
Creates a substring of this StringBuffer, starting at a specified index and ending at the end of this StringBuffer. |
String |
substring(int beginIndex,
int endIndex)
Creates a substring of this StringBuffer, starting at a specified index and ending at one character before a specified index. |
String |
toString()
Convert this StringBuffer to a String. |
| Methods inherited from class java.lang.Object |
|---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait |
| Constructor Detail |
|---|
public StringBuffer()
public StringBuffer(int capacity)
StringBuffer with the specified initial
capacity.
capacity - the initial capacity
NegativeArraySizeException - if capacity is negativepublic StringBuffer(String str)
StringBuffer with the characters in the
specified String. Initial capacity will be the size of the
String plus 16.
str - the String to convert
NullPointerException - if str is null| Method Detail |
|---|
public int length()
String this StringBuffer
would create. Not to be confused with the capacity of the
StringBuffer.
StringBuffercapacity(),
setLength(int)public int capacity()
StringBuffer can
support before it must be grown. Not to be confused with length.
StringBufferlength(),
ensureCapacity(int)public void ensureCapacity(int minimumCapacity)
StringBuffer. This will
ensure that an expensive growing operation will not occur until
minimumCapacity is reached. The buffer is grown to the
larger of minimumCapacity and
capacity() * 2 + 2, if it is not already large enough.
minimumCapacity - the new capacitycapacity()public void setLength(int newLength)
newLength
characters of the old array will be preserved, and the remaining
characters are truncated.
newLength - the new length
IndexOutOfBoundsException - if the new length is negative
(while unspecified, this is a StringIndexOutOfBoundsException)length()public char charAt(int index)
index - the index of the character to get, starting at 0
IndexOutOfBoundsException - if index is negative or >= length()
public void getChars(int srcOffset,
int srcEnd,
char[] dst,
int dstOffset)
srcOffset - srcEnd
characters will be copied into the array you pass in.
srcOffset - the index to start copying from (inclusive)srcEnd - the index to stop copying from (exclusive)dst - the array to copy intodstOffset - the index to start copying into
NullPointerException - if dst is null
IndexOutOfBoundsException - if any source or target indices are
out of range (while unspecified, source problems cause a
StringIndexOutOfBoundsException, and dest problems cause an
ArrayIndexOutOfBoundsException)System.arraycopy(Object, int, Object, int, int)
public void setCharAt(int index,
char ch)
index - the index of the character to set starting at 0ch - the value to set that character to
IndexOutOfBoundsException - if index is negative or >= length()
(while unspecified, this is a StringIndexOutOfBoundsException)public StringBuffer append(Object obj)
String value of the argument to this
StringBuffer. Uses String.valueOf() to convert
to String.
obj - the Object to convert and append
StringBufferString.valueOf(Object),
append(String)public StringBuffer append(String str)
String to this StringBuffer. If
str is null, the String "null" is appended.
str - the String to append
StringBufferpublic StringBuffer append(StringBuffer stringBuffer)
StringBuffer value of the argument to this
StringBuffer. This behaves the same as
append((Object) stringBuffer), except it is more efficient.
stringBuffer - the StringBuffer to convert and append
StringBufferappend(Object)public StringBuffer append(char[] data)
char array to this StringBuffer.
This is similar (but more efficient) than
append(new String(data)), except in the case of null.
data - the char[] to append
StringBuffer
NullPointerException - if str is nullappend(char[], int, int)
public StringBuffer append(char[] data,
int offset,
int count)
char array to this
StringBuffer. This is similar (but more efficient) than
append(new String(data, offset, count)), except in the case
of null.
data - the char[] to appendoffset - the start location in strcount - the number of characters to get from str
StringBuffer
NullPointerException - if str is null
IndexOutOfBoundsException - if offset or count is out of range
(while unspecified, this is a StringIndexOutOfBoundsException)public StringBuffer append(boolean bool)
String value of the argument to this
StringBuffer. Uses String.valueOf() to convert
to String.
bool - the boolean to convert and append
StringBufferString.valueOf(boolean)public StringBuffer append(char ch)
char to this StringBuffer.
ch - the char to append
StringBufferpublic StringBuffer append(int inum)
String value of the argument to this
StringBuffer. Uses String.valueOf() to convert
to String.
inum - the int to convert and append
StringBufferString.valueOf(int)public StringBuffer append(long lnum)
String value of the argument to this
StringBuffer. Uses String.valueOf() to convert
to String.
lnum - the long to convert and append
StringBufferString.valueOf(long)public StringBuffer append(float fnum)
String value of the argument to this
StringBuffer. Uses String.valueOf() to convert
to String.
fnum - the float to convert and append
StringBufferString.valueOf(float)public StringBuffer append(double dnum)
String value of the argument to this
StringBuffer. Uses String.valueOf() to convert
to String.
dnum - the double to convert and append
StringBufferString.valueOf(double)
public StringBuffer delete(int start,
int end)
StringBuffer.
delete(10, 12) will delete 10 and 11, but not 12. It is
harmless for end to be larger than length().
start - the first character to deleteend - the index after the last character to delete
StringBuffer
StringIndexOutOfBoundsException - if start or end are out of boundspublic StringBuffer deleteCharAt(int index)
StringBuffer.
index - the index of the character to delete
StringBuffer
StringIndexOutOfBoundsException - if index is out of bounds
public StringBuffer replace(int start,
int end,
String str)
start (inclusive) and
end (exclusive) with str. If end
is larger than the size of this StringBuffer, all characters after
start are replaced.
start - the beginning index of characters to delete (inclusive)end - the ending index of characters to delete (exclusive)str - the new String to insert
StringBuffer
StringIndexOutOfBoundsException - if start or end are out of bounds
NullPointerException - if str is nullpublic String substring(int beginIndex)
beginIndex - index to start substring (base 0)
StringIndexOutOfBoundsException - if beginIndex is out of boundssubstring(int, int)
public String substring(int beginIndex,
int endIndex)
beginIndex - index to start at (inclusive, base 0)endIndex - index to end at (exclusive)
StringIndexOutOfBoundsException - if beginIndex or endIndex is out
of bounds
public StringBuffer insert(int offset,
char[] str,
int str_offset,
int len)
char[] argument into this
StringBuffer.
offset - the place to insert in this bufferstr - the char[] to insertstr_offset - the index in str to start inserting fromlen - the number of characters to insert
StringBuffer
NullPointerException - if str is null
StringIndexOutOfBoundsException - if any index is out of bounds
public StringBuffer insert(int offset,
Object obj)
String value of the argument into this
StringBuffer. Uses String.valueOf() to convert
to String.
offset - the place to insert in this bufferobj - the Object to convert and insert
StringBuffer
StringIndexOutOfBoundsException - if offset is out of boundsString.valueOf(Object)
public StringBuffer insert(int offset,
String str)
String argument into this
StringBuffer. If str is null, the String "null" is used
instead.
offset - the place to insert in this bufferstr - the String to insert
StringBuffer
StringIndexOutOfBoundsException - if offset is out of bounds
public StringBuffer insert(int offset,
char[] data)
char[] argument into this
StringBuffer.
offset - the place to insert in this bufferdata - the char[] to insert
StringBuffer
NullPointerException - if data is null
StringIndexOutOfBoundsException - if offset is out of boundsinsert(int, char[], int, int)
public StringBuffer insert(int offset,
boolean bool)
String value of the argument into this
StringBuffer. Uses String.valueOf() to convert
to String.
offset - the place to insert in this bufferbool - the boolean to convert and insert
StringBuffer
StringIndexOutOfBoundsException - if offset is out of boundsString.valueOf(boolean)
public StringBuffer insert(int offset,
char ch)
char argument into this StringBuffer.
offset - the place to insert in this bufferch - the char to insert
StringBuffer
StringIndexOutOfBoundsException - if offset is out of bounds
public StringBuffer insert(int offset,
int inum)
String value of the argument into this
StringBuffer. Uses String.valueOf() to convert
to String.
offset - the place to insert in this bufferinum - the int to convert and insert
StringBuffer
StringIndexOutOfBoundsException - if offset is out of boundsString.valueOf(int)
public StringBuffer insert(int offset,
long lnum)
String value of the argument into this
StringBuffer. Uses String.valueOf() to convert
to String.
offset - the place to insert in this bufferlnum - the long to convert and insert
StringBuffer
StringIndexOutOfBoundsException - if offset is out of boundsString.valueOf(long)
public StringBuffer insert(int offset,
float fnum)
String value of the argument into this
StringBuffer. Uses String.valueOf() to convert
to String.
offset - the place to insert in this bufferfnum - the float to convert and insert
StringBuffer
StringIndexOutOfBoundsException - if offset is out of boundsString.valueOf(float)
public StringBuffer insert(int offset,
double dnum)
String value of the argument into this
StringBuffer. Uses String.valueOf() to convert
to String.
offset - the place to insert in this bufferdnum - the double to convert and insert
StringBuffer
StringIndexOutOfBoundsException - if offset is out of boundsString.valueOf(double)public int indexOf(String str)
str - String to find
NullPointerException - if str is nullindexOf(String, int)
public int indexOf(String str,
int fromIndex)
str - String to findfromIndex - index to start the search
NullPointerException - if str is nullpublic int lastIndexOf(String str)
str - String to find
NullPointerException - if str is nulllastIndexOf(String, int)
public int lastIndexOf(String str,
int fromIndex)
str - String to findfromIndex - index to start the search
NullPointerException - if str is nullpublic StringBuffer reverse()
StringBufferpublic String toString()
StringBuffer to a String. The
String is composed of the characters currently in this StringBuffer. Note
that the result is a copy, and that future modifications to this buffer
do not affect the String.
toString in class ObjectObject.getClass(),
Object.hashCode(),
Class.getName(),
Integer.toHexString(int)
|
|||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||