JDK帮助文档stringbuffer中文版

来源:互联网 发布:java void方法结束 编辑:程序博客网 时间:2024/05/29 09:14
概述 软件包   使用  已过时 索引 帮助 JavaTM Platform
Standard Ed. 6
 上一个类   下一个类框架    无框架    摘要: 嵌套 | 字段 | 构造方法 | 方法详细信息: 字段 | 构造方法 | 方法

java.lang
类 StringBuffer

java.lang.Object  继承者 java.lang.StringBuffer
所有已实现的接口:
Serializable, Appendable, CharSequence

public final class StringBuffer
extends Object
implements Serializable, CharSequence

线程安全的可变字符序列。一个类似于 String 的字符串缓冲区,但不能修改。虽然在任意时间点上它都包含某种特定的字符序列,但通过某些方法调用可以改变该序列的长度和内容。

可将字符串缓冲区安全地用于多个线程。可以在必要时对这些方法进行同步,因此任意特定实例上的所有操作就好像是以串行顺序发生的,该顺序与所涉及的每个线程进行的方法调用顺序一致。

StringBuffer 上的主要操作是 appendinsert 方法,可重载这些方法,以接受任意类型的数据。每个方法都能有效地将给定的数据转换成字符串,然后将该字符串的字符追加或插入到字符串缓冲区中。append 方法始终将这些字符添加到缓冲区的末端;而insert 方法则在指定的点添加字符。

例如,如果 z 引用一个当前内容为 "start" 的字符串缓冲区对象,则此方法调用 z.append("le") 会使字符串缓冲区包含 "startle",而z.insert(4, "le") 将更改字符串缓冲区,使之包含 "starlet"。

通常,如果 sb 引用 StringBuilder 的一个实例,则 sb.append(x)sb.insert(sb.length(), x) 具有相同的效果。

当发生与源序列有关的操作(如源序列中的追加或插入操作)时,该类只在执行此操作的字符串缓冲区上而不是在源上实现同步。

每个字符串缓冲区都有一定的容量。只要字符串缓冲区所包含的字符序列的长度没有超出此容量,就无需分配新的内部缓冲区数组。如果内部缓冲区溢出,则此容量自动增大。从 JDK 5 开始,为该类补充了一个单个线程使用的等价类,即StringBuilder。与该类相比,通常应该优先使用StringBuilder 类,因为它支持所有相同的操作,但由于它不执行同步,所以速度更快。

从以下版本开始:
JDK1.0
另请参见:
StringBuilder,String, 序列化表格

构造方法摘要StringBuffer()           构造一个其中不带字符的字符串缓冲区,其初始容量为 16 个字符。StringBuffer(CharSequence seq)           public java.lang.StringBuilder(CharSequence seq) 构造一个字符串缓冲区,它包含与指定的CharSequence 相同的字符。StringBuffer(int capacity)           构造一个不带字符,但具有指定初始容量的字符串缓冲区。StringBuffer(String str)           构造一个字符串缓冲区,并将其内容初始化为指定的字符串内容。  方法摘要 StringBufferappend(boolean b)           将boolean 参数的字符串表示形式追加到序列。 StringBufferappend(char c)           将char 参数的字符串表示形式追加到此序列。 StringBufferappend(char[] str)           将char 数组参数的字符串表示形式追加到此序列。 StringBufferappend(char[] str, int offset, int len)           将char 数组参数的子数组的字符串表示形式追加到此序列。 StringBufferappend(CharSequence s)           将指定的CharSequence 追加到该序列。 StringBufferappend(CharSequence s, int start, int end)           将指定CharSequence 的子序列追加到此序列。 StringBufferappend(double d)           将double 参数的字符串表示形式追加到此序列。 StringBufferappend(float f)           将float 参数的字符串表示形式追加到此序列。 StringBufferappend(int i)           将int 参数的字符串表示形式追加到此序列。 StringBufferappend(long lng)           将long 参数的字符串表示形式追加到此序列。 StringBufferappend(Object obj)           追加Object 参数的字符串表示形式。 StringBufferappend(String str)           将指定的字符串追加到此字符序列。 StringBufferappend(StringBuffer sb)           将指定的StringBuffer 追加到此序列中。 StringBufferappendCodePoint(int codePoint)           将codePoint 参数的字符串表示形式追加到此序列。 intcapacity()           返回当前容量。 charcharAt(int index)           返回此序列中指定索引处的char 值。 intcodePointAt(int index)           返回指定索引处的字符(统一代码点)。 intcodePointBefore(int index)           返回指定索引前的字符(统一代码点)。 intcodePointCount(int beginIndex, int endIndex)           返回此序列指定文本范围内的统一代码点。 StringBufferdelete(int start, int end)           移除此序列的子字符串中的字符。 StringBufferdeleteCharAt(int index)           移除此序列指定位置的char voidensureCapacity(int minimumCapacity)           确保容量至少等于指定的最小值。 voidgetChars(int srcBegin, int srcEnd, char[] dst, int dstBegin)           将字符从此序列复制到目标字符数组dst intindexOf(String str)           返回第一次出现的指定子字符串在该字符串中的索引。 intindexOf(String str, int fromIndex)           从指定的索引处开始,返回第一次出现的指定子字符串在该字符串中的索引。 StringBufferinsert(int offset, boolean b)           将boolean 参数的字符串表示形式插入此序列中。 StringBufferinsert(int offset, char c)           将char 参数的字符串表示形式插入此序列中。 StringBufferinsert(int offset, char[] str)           将char 数组参数的字符串表示形式插入此序列中。 StringBufferinsert(int index, char[] str, int offset, int len)           将数组参数str 的子数组的字符串表示形式插入此序列中。 StringBufferinsert(int dstOffset, CharSequence s)           将指定 CharSequence 插入此序列中。 StringBufferinsert(int dstOffset, CharSequence s, int start, int end)           将指定 CharSequence 的子序列插入此序列中。 StringBufferinsert(int offset, double d)           将double 参数的字符串表示形式插入此序列中。 StringBufferinsert(int offset, float f)           将float 参数的字符串表示形式插入此序列中。 StringBufferinsert(int offset, int i)           将int 参数的字符串表示形式插入此序列中。 StringBufferinsert(int offset, long l)           将long 参数的字符串表示形式插入此序列中。 StringBufferinsert(int offset, Object obj)           将 Object 参数的字符串表示形式插入此字符序列中。 StringBufferinsert(int offset, String str)           将字符串插入此字符序列中。 intlastIndexOf(String str)           返回最右边出现的指定子字符串在此字符串中的索引。 intlastIndexOf(String str, int fromIndex)           返回最后一次出现的指定子字符串在此字符串中的索引。 intlength()           返回长度(字符数)。 intoffsetByCodePoints(int index, int codePointOffset)           返回此序列中的一个索引,该索引是从给定index 偏移 codePointOffset 个代码点后得到的。 StringBufferreplace(int start, int end,String str)           使用给定String 中的字符替换此序列的子字符串中的字符。 StringBufferreverse()           将此字符序列用其反转形式取代。 voidsetCharAt(int index, char ch)           将给定索引处的字符设置为ch voidsetLength(int newLength)           设置字符序列的长度。 CharSequencesubSequence(int start, int end)           返回一个新的字符序列,该字符序列是此序列的子序列。 Stringsubstring(int start)           返回一个新的String,它包含此字符序列当前所包含的字符子序列。 Stringsubstring(int start, int end)           返回一个新的String,它包含此序列当前所包含的字符子序列。 StringtoString()           返回此序列中数据的字符串表示形式。 voidtrimToSize()           尝试减少用于字符序列的存储空间。 从类 java.lang.Object 继承的方法clone, equals,finalize, getClass,hashCode, notify, notifyAll, wait, wait,wait 

构造方法详细信息

StringBuffer

public StringBuffer()
构造一个其中不带字符的字符串缓冲区,其初始容量为 16 个字符。


StringBuffer

public StringBuffer(int capacity)
构造一个不带字符,但具有指定初始容量的字符串缓冲区。

参数:
capacity - 初始容量。
抛出:
NegativeArraySizeException - 如果capacity 参数小于 0

StringBuffer

public StringBuffer(String str)
构造一个字符串缓冲区,并将其内容初始化为指定的字符串内容。该字符串的初始容量为 16 加上字符串参数的长度。

参数:
str - 缓冲区的初始内容。
抛出:
NullPointerException - 如果strnull

StringBuffer

public StringBuffer(CharSequence seq)
public java.lang.StringBuilder(CharSequence seq) 构造一个字符串缓冲区,它包含与指定的 CharSequence 相同的字符。该字符串缓冲区的初始容量为 16 加上 CharSequence 参数的长度。

如果指定的 CharSequence 的长度小于或等于 0,则返回容量为 16 的空缓冲区。

参数:
seq - 要复制的序列。
抛出:
NullPointerException - 如果seqnull
从以下版本开始:
1.5
方法详细信息

length

public int length()
返回长度(字符数)。

指定者:
接口 CharSequence 中的length
返回:
此对象表示的当前字符序列的长度。

capacity

public int capacity()
返回当前容量。容量指可用于最新插入的字符的存储量,超过这一容量就需要再次进行分配。

返回:
当前容量。

ensureCapacity

public void ensureCapacity(int minimumCapacity)
确保容量至少等于指定的最小值。如果当前容量小于 minimumCapacity 参数,则可分配一个具有更大容量的新的内部数组。新容量的大小应大于:
  • minimumCapacity 参数。
  • 旧容量的两倍加 2
如果 minimumCapacity 参数为非正数,则此方法不执行任何操作并返回。

参数:
minimumCapacity - 所需的最小容量。

trimToSize

public void trimToSize()
尝试减少用于字符序列的存储空间。如果缓冲区大于保存当前字符序列所需的存储空间,则将重新调整其大小,以便更好地利用存储空间。调用此方法可能会影响后续调用capacity() 方法时返回的值(但不要求如此)。

从以下版本开始:
1.5

setLength

public void setLength(int newLength)
设置字符序列的长度。序列将被更改为一个新的字符序列,新序列的长度由参数指定。对于每个小于 newLength 参数的非负索引k,如果 k 小于原字符序列的长度,则新字符序列索引 k 处的字符与原字符序列索引 k 处的字符相同;否则,新字符序列索引k 处的字符将是 null 字符 '\u0000'。换句话说,如果 newLength 参数小于当前长度,则长度将更改为指定的长度。

如果 newLength 参数大于或等于当前长度,则将追加有效的 null 字符 ('\u0000'),使长度满足newLength 参数。

newLength 参数必须大于或等于 0

参数:
newLength - 新长度
抛出:
IndexOutOfBoundsException - 如果newLength 参数为负。
另请参见:
length()

charAt

public char charAt(int index)
返回此序列中指定索引处的 char 值。第一个 char 值在索引 0 处,第二个在索引1 处,依此类推,这类似于数组索引。

index 参数必须大于等于 0,且小于此序列的长度。

如果索引处指定的 char 值是一个代理项,则返回该代理项的值。

指定者:
接口 CharSequence 中的charAt
参数:
index - 所需 char 值的索引。
返回:
指定索引处的 char 值。
抛出:
IndexOutOfBoundsException - 如果index 为负或大于等于 length()
另请参见:
length()

codePointAt

public int codePointAt(int index)
返回指定索引处的字符(统一代码点)。该索引引用 char 值(Unicode 代码单元),其范围是从 0length() - 1

如果给定索引指定的 char 值属于高代理项范围,则后续索引小于此序列的长度;如果后续索引处的 char 值属于低代理项范围,则返回此代理项对 (surrogate pair) 对应的增补代码点。否则,返回给定索引处的char 值。

参数:
index - char 值的索引。
返回:
index 处字符的代码点值。
从以下版本开始:
1.5

codePointBefore

public int codePointBefore(int index)
返回指定索引前的字符(统一代码点)。该索引引用 char 值(Unicode 代码单元),其范围是从 1length()

如果 (index - 1) 处的 char 值属于低代理项范围,则 (index - 2) 为非负;如果(index - 2) 处的char 值属于高代理项范围,则返回该代理项对的增补代码点值。如果 index - 1 处的 char 值是未配对的低(高)代理项,则返回代理项值。

参数:
index - 应该返回的代码点之后的索引。
返回:
给定索引之前的 Unicode 代码点值。
从以下版本开始:
1.5

codePointCount

public int codePointCount(int beginIndex,                          int endIndex)
返回此序列指定文本范围内的统一代码点。文本范围始于指定的 beginIndex,并扩展到索引 endIndex - 1 上的char。因此文本范围的长度(char 形式)为 endIndex-beginIndex。该序列中每个未配对的代理项都被作为一个代码点进行计数。

参数:
beginIndex - 文本范围的第一个 char 的索引。
endIndex - 文本范围的最后一个 char 之后的索引。
返回:
指定文本范围内的 Unicode 代码点的数量。
从以下版本开始:
1.5

offsetByCodePoints

public int offsetByCodePoints(int index,                              int codePointOffset)
返回此序列中的索引,该索引是从给定 index 偏移 codePointOffset 个代码点后得到的。indexcodePointOffset 给出的文本范围内的不成对代理项是按一个代码点算作一个项进行计数的。

参数:
index - 将进行偏移的索引
codePointOffset - 用代码点计算的偏移量
返回:
此序列中的索引
从以下版本开始:
1.5

getChars

public void getChars(int srcBegin,                     int srcEnd,                     char[] dst,                     int dstBegin)
将字符从此序列复制到目标字符数组 dst。要复制的第一个字符在索引 srcBegin 处;要复制的最后一个字符在索引srcEnd-1 处。要复制的字符总数为 srcEnd-srcBegin。要复制到 dst 子数组的字符从索引dstBegin 处开始,结束于以下索引:

 dstbegin + (srcEnd-srcBegin) - 1 

参数:
srcBegin - 从此偏移量处开始复制。
srcEnd - 在此偏移量处停止复制。
dst - 用来保存复制数据的数组。
dstBegin - dst 中的偏移量。
抛出:
NullPointerException - 如果dstnull
IndexOutOfBoundsException - 如果以下任意一项为 true:
  • srcBegin 为负
  • dstBegin 为负
  • srcBegin 参数大于 srcEnd 参数。
  • srcEnd 大于 this.length()
  • dstBegin+srcEnd-srcBegin 大于 dst.length

setCharAt

public void setCharAt(int index,                      char ch)
将给定索引处的字符设置为 ch。此序列将被转换,以表示等同于原字符序列的新字符序列,唯一的不同在于新序列在 index 处包含 ch

index 参数必须大于等于 0,且小于此序列的长度。

参数:
index - 要修改的字符的索引。
ch - 新字符。
抛出:
IndexOutOfBoundsException - 如果index 为负或大于等于 length()
另请参见:
length()

append

public StringBuffer append(Object obj)
追加 Object 参数的字符串表示形式。

参数将被转换成字符串,就好象使用了 String.valueOf 方法一样。然后,将所得字符串中的字符追加到此序列。

参数:
obj - 一个 Object
返回:
此对象的一个引用。
另请参见:
String.valueOf(java.lang.Object),append(java.lang.String)

append

public StringBuffer append(String str)
将指定的字符串追加到此字符序列。

按顺序追加 String 变量中的字符,使此序列增加该变量的长度。如果 strnull,则追加 4 个字符"null"

假设此字符序列的长度在执行 append 方法前为 n。如果 k 小于 n,则新字符序列中索引k 处的字符等于原序列中索引 k 处的字符;否则它等于参数 str 中索引 k-n 处的字符。

参数:
str - 一个 string。
返回:
此对象的一个引用。

append

public StringBuffer append(StringBuffer sb)
将指定的 StringBuffer 追加到此序列中。

按顺序将 StringBuffer 参数中的字符追加到此 StringBuffer 中,并使 StringBuffer 在长度上增加该参数的长度。如果sbnull,则将 4 个 "null" 字符追加到此 StringBuffer 中。

在执行 append 方法前,让 StringBuffer 中包含的原有字符序列的长度为 n。如果 k 小于 n,则新字符序列中索引 k 处的字符等于原有字符序列中索引 k 处的字符;否则它等于参数sb 中索引 k-n 处的字符。

该方法在 this(目标)对象上实现同步,但不在源(sb)上实现同步。

参数:
sb - 要追加的 StringBuffer
返回:
该对象的一个引用。
从以下版本开始:
1.4

append

public StringBuffer append(CharSequence s)
将指定的 CharSequence 追加到该序列。

按顺序将 CharSequence 参数中的字符追加到该序列中,使该序列增加该参数的长度。

该方法的结果与调用 this.append(s, 0, s.length()) 的结果完全相同;

该方法在 this(目标)对象上实现同步,但不在源(s)上实现同步。

如果 snull,则追加 4 个 "null" 字符。

指定者:
接口 Appendable 中的append
参数:
s - 要追加的 CharSequence
返回:
此对象的一个引用。
从以下版本开始:
1.5

append

public StringBuffer append(CharSequence s,                           int start,                           int end)
将指定 CharSequence 的子序列追加到此序列。

按顺序追加参数 s 中的字符,即从索引 start 开始到索引 end 结束的此序列的内容。此序列增加的长度为end - start

假设此字符序列的长度在执行 append 方法前为 n。如果 k 小于 n,则新字符序列中索引k 处的字符等于原序列中索引 k 处的字符;否则它等于参数 s 中索引 k+start-n 处的字符。

如果 snull,则认为 s 参数包含 4 个字符 "null",并以此为根据追加字符。

指定者:
接口 Appendable 中的append
参数:
s - 要追加的序列。
start - 要追加的子序列的起始索引。
end - 要追加的子序列的结束索引。
返回:
此对象的一个引用。
抛出:
IndexOutOfBoundsException 如果startend 为负;或者 start 大于 end;或者end 大于 s.length()
从以下版本开始:
1.5

append

public StringBuffer append(char[] str)
char 数组参数的字符串表示形式追加到此序列。

按顺序将数组参数中的字符追加到此序列的内容中。此字符将增加该参数的长度。

该方法的总体效果与以下操作过程的效果相同:先使用 String.valueOf(char[]) 方法将参数转换为字符串,然后将所得字符串的字符追加到此字符序列。

参数:
str - 要追加的字符。
返回:
此对象的一个引用。

append

public StringBuffer append(char[] str,                           int offset,                           int len)
char 数组参数的子数组的字符串表示形式追加到此序列。

char 数组 str 中的字符按顺序追加到此序列的内容中,从索引 offset 开始。此字符的长度将增加len

该方法的最终效果与以下操作过程的效果相同:先使用 String.valueOf(char[]) 方法将参数转换为字符串,然后将所得字符串的字符追加到此字符序列。

参数:
str - 要追加的字符。
offset - 要追加的第一个 char 的索引。
len - 要追加的 char 的数量。
返回:
此对象的一个引用。

append

public StringBuffer append(boolean b)
boolean 参数的字符串表示形式追加到序列。

参数将被转换成字符串,就好象使用了 String.valueOf 方法一样。然后,将所得字符串中的字符追加到此序列。

参数:
b - 一个 boolean 值。
返回:
此对象的一个引用。
另请参见:
String.valueOf(boolean), append(java.lang.String)

append

public StringBuffer append(char c)
char 参数的字符串表示形式追加到此序列。

参数将被追加到此序列。此序列的长度将增加 1

该方法的最终效果与以下操作过程的效果相同:先使用 String.valueOf(char[]) 方法将参数转换为字符串,然后将所得字符串的字符追加到此字符序列。

指定者:
接口 Appendable 中的append
参数:
c - 一个 char 值。
返回:
此对象的一个引用。

append

public StringBuffer append(int i)
int 参数的字符串表示形式追加到此序列。

参数将被转换成字符串,就好象使用了 String.valueOf 方法一样。然后,将所得字符串中的字符追加到此序列。

参数:
i - 一个 int 值。
返回:
此对象的一个引用。
另请参见:
String.valueOf(int), append(java.lang.String)

appendCodePoint

public StringBuffer appendCodePoint(int codePoint)
codePoint 参数的字符串表示形式追加到此序列。

参数将被追加到此序列。此序列的长度将增加 Character.charCount(codePoint)

该方法的最终效果与以下操作过程的效果相同:先使用 Character.toChars(int) 方法将char 数组转换为字符串,然后将所得字符串的字符追加到此字符序列。

参数:
codePoint - 一个 Unicode 代码点
返回:
此对象的一个引用。
从以下版本开始:
1.5

append

public StringBuffer append(long lng)
long 参数的字符串表示形式追加到此序列。

参数将被转换成字符串,就好象使用了 String.valueOf 方法一样。然后,将所得字符串中的字符追加到此序列。

参数:
lng - 一个 long 值。
返回:
此对象的一个引用。
另请参见:
String.valueOf(long), append(java.lang.String)

append

public StringBuffer append(float f)
float 参数的字符串表示形式追加到此序列。

参数将被转换成字符串,就好象使用了 String.valueOf 方法一样。然后被所得字符串中的字符追加到此字符串序列。

参数:
f - 一个 float 值。
返回:
此对象的一个引用。
另请参见:
String.valueOf(float), append(java.lang.String)

append

public StringBuffer append(double d)
double 参数的字符串表示形式追加到此序列。

参数将被转换成字符串,就好象使用了 String.valueOf 方法一样。然后,将所得字符串中的字符追加到此序列。

参数:
d - 一个 double 值。
返回:
此对象的一个引用。
另请参见:
String.valueOf(double), append(java.lang.String)

delete

public StringBuffer delete(int start,                           int end)
移除此序列的子字符串中的字符。该子字符串从指定的 start 处开始,一直到索引 end - 1 处的字符,如果不存在这种字符,则一直到序列尾部。如果start 等于 end,则不发生任何更改。

参数:
start - 起始索引(包含)。
end - 结束索引(不包含)。
返回:
此对象。
抛出:
StringIndexOutOfBoundsException - 如果start 为负、大于 length() 或大于 end
从以下版本开始:
1.2

deleteCharAt

public StringBuffer deleteCharAt(int index)
移除此序列指定位置的 char。此序列将缩短一个 char

注:如果给定索引处的字符是增补字符,则此方法将不会移除整个字符。如果需要准确处理增补字符,那么可以通过调用 Character.charCount(thisSequence.codePointAt(index))(用此序列取代thisSequence)来确定要移除的 char 的数量。

参数:
index - 要移除的 char 的索引
返回:
此对象。
抛出:
StringIndexOutOfBoundsException - 如果index 为负或大于等于 length()
从以下版本开始:
1.2

replace

public StringBuffer replace(int start,                            int end,                            String str)
使用给定 String 中的字符替换此序列的子字符串中的字符。该子字符串从指定的 start 处开始,一直到索引end - 1 处的字符,如果不存在这种字符,则一直到序列尾部。先将子字符串中的字符移除,然后将指定的 String 插入start。(如果需要,序列将延长以适应指定的字符串。)

参数:
start - 起始索引(包含)。
end - 结束索引(不包含)。
str - 将替换原有内容的字符串。
返回:
此对象。
抛出:
StringIndexOutOfBoundsException - 如果start 为负、大于 length() 或大于 end
从以下版本开始:
1.2

substring

public String substring(int start)
返回一个新的 String,它包含此字符序列当前所包含的字符子序列。该子字符串始于指定索引处的字符,一直到此字符串末尾。

参数:
start - 起始索引(包含)。
返回:
新的字符串。
抛出:
StringIndexOutOfBoundsException - 如果start 小于 0,或大于此对象的长度。
从以下版本开始:
1.2

subSequence

public CharSequence subSequence(int start,                                int end)
返回一个新的字符序列,该字符序列是此序列的子序列。

调用该方法的形式为:

 sb.subSequence(begin, end)
与下列方法调用完全相同:
 sb.substring(begin, end)
提供此方法是为了使此类能够实现 CharSequence 接口。

指定者:
接口 CharSequence 中的subSequence
参数:
start - 起始索引(包含)。
end - 结束索引(不包含)。
返回:
指定子序列。
抛出:
IndexOutOfBoundsException - 如果startend 为负数;如果 end 大于 length(),或者 start 大于end
从以下版本开始:
1.4

substring

public String substring(int start,                        int end)
返回一个新的 String,它包含此序列当前所包含的字符子序列。该子字符串从指定的 start 处开始,一直到索引end - 1 处的字符。

参数:
start - 起始索引(包含)。
end - 结束索引(不包含)。
返回:
新的字符串。
抛出:
StringIndexOutOfBoundsException - 如果startend 为负数或大于 length();如果 start 大于end
从以下版本开始:
1.2

insert

public StringBuffer insert(int index,                           char[] str,                           int offset,                           int len)
str 数组参数的子数组的字符串表示形式插入此序列中。其中子数组从指定的 offset 开始,包含lenchar。子数组的字符将被插入 index 所指示的位置。此序列的长度将增加lenchar

参数:
index - 要插入子数组中的位置。
str - 一个 char 数组。
offset - 将插入子数组中的第一个 char 的索引。
len - 将插入子数组中的 char 的数量。
返回:
此对象
抛出:
StringIndexOutOfBoundsException - 如果index 为负或大于 length();或者 offsetlen 为负;或者(offset+len) 大于 str.length
从以下版本开始:
1.2

insert

public StringBuffer insert(int offset,                           Object obj)
Object 参数的字符串表示形式插入此字符序列中。

第二个参数将被转换成字符串,就好象使用了 String.valueOf 方法一样。然后,将所得字符串中的字符追加到此序列。

offset 参数必须大于等于 0,且小于等于此序列的长度。

参数:
offset - 偏移量。
obj - 一个 Object
返回:
此对象的一个引用。
抛出:
StringIndexOutOfBoundsException - 如果 offset 参数无效。
另请参见:
String.valueOf(java.lang.Object),insert(int, java.lang.String), length()

insert

public StringBuffer insert(int offset,                           String str)
将字符串插入此字符序列中。

按顺序将 String 参数中的字符插入此序列中的指定位置,将该位置处原来的字符向后移,此序列将增加该参数的长度。如果 strnull,则向此序列中追加 4 个字符 "null"

新字符序列在索引 k 处的字符有以下几种情况:

  • 如果 k 小于 offset,则等于原字符序列中索引 k 处的字符。
  • 如果 k 不小于 offset 但小于 offset+str.length(),则等于str 参数中索引 k-offset 中的字符。
  • 如果 k 不小于 offset+str.length(),则等于原字符序列中索引 k-str.length() 处的字符

offset 参数必须大于等于 0,且小于等于此序列的长度。

参数:
offset - 偏移量。
str - 一个 string。
返回:
此对象的一个引用。
抛出:
StringIndexOutOfBoundsException - 如果 offset 参数无效。
另请参见:
length()

insert

public StringBuffer insert(int offset,char[] str)
char 数组参数的字符串表示形式插入此序列中。

数组参数的字符将被插入此序列中 offset 所指示的位置处。此字符将增加该参数的长度。

该方法的最终效果与以下操作过程的效果相同:先使用 String.valueOf(char[]) 方法将参数转换为字符串,然后将所得字符串的字符插入到此字符序列中offset 所指示的位置。

参数:
offset - 偏移量。
str - 一个字符数组。
返回:
此对象的一个引用。
抛出:
StringIndexOutOfBoundsException - 如果 offset 参数无效。

insert

public StringBuffer insert(int dstOffset,CharSequence s)
将指定 CharSequence 插入此序列中。

按顺序将 CharSequence 参数中的字符插入此序列中的指定位置,位于该位置处的原来的字符则将向后推移,此序列将增加该参数的长度。

此方法的最终效果与调用此对象的 insert(dstOffset, s, 0, s.length()) 方法的效果完全相同。

如果 snull,则向此序列中追加 4 个字符 "null"

参数:
dstOffset - 偏移量。
s - 要插入的序列。
返回:
此对象的一个引用。
抛出:
StringIndexOutOfBoundsException - 如果 offset 参数无效。
从以下版本开始:
1.5

insert

public StringBuffer insert(int dstOffset,                           CharSequence s,                           int start,                           int end)
将指定 CharSequence 的子序列插入此序列中。

参数 s 中,由 startend 指示的子序列将按顺序被插入此序列指定的目标偏移量处,位于该位置的任何原有字符都将向后移。序列的长度将增加end - start

此字符序列在索引 k 处的字符将有以下几种情况:

  • 如果 k 小于 dstOffset,则等于原字符序列中索引 k 处的字符
  • 如果 k 大于等于 dstOffset 但小于 dstOffset+end-start,则等于s 参数中索引 k+start-dstOffset 处的字符
  • 如果 k 大于等于 dstOffset+end-start,则等于此序列中索引 k-(end-start) 处的字符

dstOffset 参数必须大于等于 0,并小于等于此序列的长度。

start 参数必须为非负,但不得大于 end

end 数必须大于等于 start,且小于等于 s 的长度。

如果 snull,则认为 s 参数包含 4 个字符 "null",并以此为根据插入字符。

参数:
dstOffset - 此序列中的偏移量。
s - 要插入的序列。
start - 要插入的子序列的起始索引。
end - 要插入的子序列的结束索引。
返回:
此对象的一个引用。
抛出:
IndexOutOfBoundsException - 如果dstOffset 为负或大于 this.length();或者 startend 为负;或者 start 大于 end;或者 end 大于 s.length()
从以下版本开始:
1.5

insert

public StringBuffer insert(int offset,                           boolean b)
boolean 参数的字符串表示形式插入此序列中。

第二个参数将被转换成字符串,就好象使用了 String.valueOf 方法一样。然后,将所得字符串中的字符追加到此序列。

offset 参数必须大于等于 0,且小于等于此序列的长度。

参数:
offset - 偏移量。
b - 一个 boolean 值。
返回:
此对象的一个引用。
抛出:
StringIndexOutOfBoundsException - 如果 offset 参数无效。
另请参见:
String.valueOf(boolean), insert(int, java.lang.String), length()

insert

public StringBuffer insert(int offset,                           char c)
char 参数的字符串表示形式插入此序列中。

第二个参数将被插入此序列中 offset 指示的位置处。此序列的长度将增加 1。

该方法的最终效果与以下操作的效果相同:先使用 String.valueOf(char) 方法将参数转换为字符串,然后将所得字符串中的字符插入此字符序列中offset 指定的位置处。

offset 参数必须大于等于 0,且小于等于此序列的长度。

参数:
offset - 偏移量。
c - 一个 char 值。
返回:
此对象的一个引用。
抛出:
StringIndexOutOfBoundsException - 如果 offset 参数无效。
另请参见:
length()

insert

public StringBuffer insert(int offset,                           int i)
int 参数的字符串表示形式插入此序列中。

第二个参数将被转换成字符串,就好象使用了 String.valueOf 方法一样。然后,将所得字符串中的字符追加到此序列。

offset 参数必须大于等于 0,且小于等于此序列的长度。

参数:
offset - 偏移量。
i - 一个 int 值。
返回:
此对象的一个引用。
抛出:
StringIndexOutOfBoundsException - 如果 offset 参数无效。
另请参见:
String.valueOf(int), insert(int, java.lang.String), length()

insert

public StringBuffer insert(int offset,                           long l)
long 参数的字符串表示形式插入此序列中。

第二个参数将被转换成字符串,就好象使用了 String.valueOf 方法一样。然后,将所得字符串中的字符追加到此序列中 offset 指示的位置处。

offset 参数必须大于等于 0,且小于等于此序列的长度。

参数:
offset - 偏移量。
l - 一个 long 值。
返回:
此对象的一个引用。
抛出:
StringIndexOutOfBoundsException - 如果 offset 参数无效。
另请参见:
String.valueOf(long), insert(int, java.lang.String), length()

insert

public StringBuffer insert(int offset,                           float f)
float 参数的字符串表示形式插入此序列中。

第二个参数将被转换成字符串,就好象使用了 String.valueOf 方法一样。然后,将所得字符串中的字符追加到此序列。

offset 参数必须大于等于 0,且小于等于此序列的长度。

参数:
offset - 偏移量。
f - 一个 float 值。
返回:
此对象的一个引用。
抛出:
StringIndexOutOfBoundsException - 如果 offset 参数无效。
另请参见:
String.valueOf(float), insert(int, java.lang.String), length()

insert

public StringBuffer insert(int offset,                           double d)
double 参数的字符串表示形式插入此序列中。

第二个参数将被转换成字符串,就好象使用了 String.valueOf 方法一样。然后,将所得字符串中的字符追加到此序列。

offset 参数必须大于等于 0,且小于等于此序列的长度。

参数:
offset - 偏移量。
d - 一个 double 值。
返回:
此对象的一个引用。
抛出:
StringIndexOutOfBoundsException - 如果 offset 参数无效。
另请参见:
String.valueOf(double), insert(int, java.lang.String), length()

indexOf

public int indexOf(String str)
返回第一次出现的指定子字符串在该字符串中的索引。返回的整数是满足以下条件的最小 k 值:
 this.toString().startsWith(str, k) 

参数:
str - 任意字符串。
返回:
如果字符串参数是作为一个子字符串出现在该对象中,则返回第一个这样的子字符串的第一个字符的索引;如果它不是作为一个子字符串出现,则返回 -1
抛出:
NullPointerException - 如果strnull
从以下版本开始:
1.4

indexOf

public int indexOf(String str,                   int fromIndex)
从指定的索引处开始,返回第一次出现的指定子字符串在该字符串中的索引。返回的整数是满足以下条件的最小 k 值:
     k >= Math.min(fromIndex, str.length()) &&                   this.toString().startsWith(str, k) 
如果不存在这样的 k 值,则返回 -1。

参数:
str - 要搜索的子字符串。
fromIndex - 搜索开始处的索引。
返回:
从指定的索引处开始,返回第一次出现的指定子字符串在该字符串中的索引。
抛出:
NullPointerException - 如果strnull
从以下版本开始:
1.4

lastIndexOf

public int lastIndexOf(String str)
返回最右边出现的指定子字符串在此字符串中的索引。将最右边的空字符串 "" 视为出现在索引值 this.length() 处。返回的索引是满足以下条件的最大k 值:
 this.toString().startsWith(str, k) 

参数:
str - 要搜索的子字符串。
返回:
如果在该对象中字符串参数是作为一个子字符串出现多次,则返回最后一个这种子字符串的第一个字符。如果它不是作为一个子字符串出现,则返回 -1
抛出:
NullPointerException - 如果strnull
从以下版本开始:
1.4

lastIndexOf

public int lastIndexOf(String str,                       int fromIndex)
返回最后一次出现的指定子字符串在此字符串中的索引。返回的整数是满足以下条件的最大 k 值:
     k <= Math.min(fromIndex, str.length()) &&                   this.toString().startsWith(str, k) 
如果不存在这样的 k 值,则返回 -1。

参数:
str - 要搜索的子字符串。
fromIndex - 搜索开始处的索引。
返回:
最后一次出现的指定子字符串在此字符串中的索引。
抛出:
NullPointerException - 如果strnull
从以下版本开始:
1.4

reverse

public StringBuffer reverse()
将此字符序列用其反转形式取代。如果序列中存在代理项对 (surrogate pair),在 reverse 操作中将其作为单个字符处理。因此,高-低代理项的顺序不会反转。假设n 为执行 reverse 方法前此字符序列的字符长度(并非 char 值的长度),则新字符序列中索引k 处的字符将等于原字符序列索引 n-k-1 处的字符。

注意,进行 reverse 操作后,执行操作前未成对的低代理项和高代理项将成为代理项对。例如,反转 "\uDC00\uD800" 将生成有效的代理项对 "\uD800\uDC00"。

返回:
此对象的一个引用。
从以下版本开始:
JDK1.0.2

toString

public String toString()
返回此序列中数据的字符串表示形式。分配一个新的 String 对象,并将它初始化,以包含当前由此对象表示的字符串序列。然后返回此String。对此序列的后续更改不影响该 String 的内容。

指定者:
接口 CharSequence 中的toString
返回:
此字符序列的字符串表示形式。

概述 软件包   使用  已过时 索引 帮助 JavaTM Platform
Standard Ed. 6
 上一个类   下一个类框架    无框架    摘要: 嵌套 | 字段 | 构造方法 | 方法详细信息: 字段 | 构造方法 | 方法
提交错误或意见
有关更多的 API 参考资料和开发人员文档,请参阅 Java SE 开发人员文档。该文档包含更详细的、面向开发人员的描述,以及总体概述、术语定义、使用技巧和工作代码示例。

版权所有 2007 Sun Microsystems, Inc. 保留所有权利。 请遵守许可证条款。另请参阅文档重新分发政策。

0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 裁剪袖子开口偏了1公分怎么办 对于这乱扔垃圾不听劝者该怎么办 感觉被南通蒲公英店铺骗了怎么办 6个月宝宝吃米粉不吃奶怎么办 十个月的宝宝不吃辅食怎么办 5个月宝宝拉肚子有泡沫怎么办 生完孩子后皮肤暗黄怎么办 开服装店批发服装的吊牌怎么办 天虹的鞋一天就坏了怎么办 车被钥匙划了露底漆了怎么办 数控铣z轴回不了参考点怎么办 白色衣服被黑色衣服染了怎么办 夏天出汗衣服粘身上都是毛毛怎么办 支付宝租的手机坏了怎么办 新买的衣服布料扎人怎么办 洗衣服的时候卫生纸沾裤子上怎么办 洗衣服给白衣服染上色了怎么办 不小心喝了游泳池的水怎么办 铁水中硅的含量高了怎么办 视频拍摄单人变双人是怎么办的 四季青进来的货比淘宝还贵怎么办 淘宝还没收货价格买贵了怎么办 在微信上赌博庄跑了怎么办 微信赌博输了10000多怎么办 欠了信用卡说来来家里调查怎么办 没用过的超市购物卡丢了怎么办 体验服抢号成功手机号填错了怎么办 起亚kx3一键启动钥匙没电怎么办 逆战下载的时候显示文件损坏怎么办 移动公司买手机送话费套路怎么办 开通京东白条身份信息被占用怎么办 丰巢快递柜把东西寄丢了怎么办? 圆通快递把我寄的东西弄丢了怎么办 快递把我寄出去的东西弄丢了怎么办 京东被盗刷都是到付怎么办 订机票时护照号错了怎么办 请问网上不小心点了扣话费了怎么办 不小心被中国移动扣了话费怎么办 京东买东西已经付款了说无货怎么办 不小心提交了两次中信信用卡怎么办 淘宝买东西扣了银行卡两次钱怎么办