用法一源代码:
public synchronized StringBuffer append(CharSequence s, int start, int end)
{
super.append(s, start, end);
return this;
}
说明:append的第一个参数为字符串,第二个参数为开始字符,第三个参数为要追加的字符的个数。
用法二源代码:
public synchronized StringBuffer append(char str[], int offset, int len)
{
super.append(str, offset, len);
return this;
}
说明:append第一个参数为字符数组,第二个参数为开始字符,第三个参数为字符数组的长度。
测试:
public class TestAppend {
public static StringBuffer appendTestOne(StringBuffer s,String sadd,int m,int n ) {
return s.append(sadd,m,n);
}
public static StringBuffer appendTestTwo(StringBuffer s,char str[],int m,int n ) {
return s.append(str,m,n);
}
public static void main(String[] args) {
StringBuffer s = new StringBuffer("Hello ");
String sadd="abcdWorld!!";
char str[] = {'a','b','c','d','W','o','r','l','d','!','!'};
int m = 4;
int n = 6;
StringBuffer resultOne = TestAppend.appendTestOne(s,sadd,m,sadd.length());
System.out.println("调用appendTestOne(StringBuffer s,String sadd,int m,int n )的结果为:"+resultOne+"\n");
System.out.println("the value of 's' is "+s+"\n");
StringBuffer s1 = new StringBuffer("Hello ");
StringBuffer resultTwo = TestAppend.appendTestTwo(s1, str, m,n);
System.out.println("调用appendTestTwo(StringBuffer s1,char str[],int m,int n )的结果为:"+resultTwo+"\n");
}
}
运行结果:
STringBuilder和StringBuffer类似:
public class TestAppend {
public StringBuilder appendTestOne(StringBuilder s,String sadd,int m,int n ) {
return s.append(sadd,m,n);
}
public StringBuilder appendTestTwo(StringBuilder s,char str[],int m,int n ) {
return s.append(str,m,n);
}
public StringBuilder insertTest(StringBuilder s, int m, String sin) {
return s.insert(m, sin);
}
public static void main(String[] args) {
StringBuilder s = new StringBuilder("Hello ");
String sadd="abcdWorld!!";
char str[] = {'a','b','c','d','W','o','r','l','d','!','!'};
int m = 4;
int n = 10;
StringBuilder resultOne = new TestAppend().appendTestOne(s,sadd,m,n);
System.out.println("调用appendTestOne(StringBuffer s,String sadd,int m,int n )的结果为:"+resultOne+"\n");
System.out.println("The value of 's' now is "+s+"\n");
StringBuilder s1 = new StringBuilder("Hello ");
StringBuilder resultTwo = new TestAppend().appendTestTwo(s1, str, m,n-m);
System.out.println("调用appendTestTwo(StringBuffer s1,char str[],int m,int n )的结果为:"+resultTwo+"\n");
StringBuilder s2 = new StringBuilder("Hello !");
String sin= "y";
StringBuilder resultThree = new TestAppend().insertTest(s2, 6, sin);
System.out.println("调用insertTest(StringBuilder s, int m, String sin)的结果为:"+resultThree);
}
}
区别在于:
如果可能,建议优先采用该类,因为在大多数实现中,它比 StringBuffer 要快。 在 StringBuilder 上的主要操作是 append 和 insert 方法。每个方法都能有效地将给定的数据转换成字符串,然后将该字符串的字符添加或插入到字符串生成器中。append 方法始终将这些字符添加到生成器的末端;而 insert 方法则在指定的点添加字符。 例如,如果 z 引用一个当前内容为“start”的字符串生成器对象,则该方法调用 z.append("le") 将使字符串生成器包含“startle”,而 z.insert(4, "le") 将更改字符串生成器,使之包含“starlet”。 通常,如果 sb 引用 StringBuilder 的实例(StringBuilder sb = new StringBuilder();),则 sb.append(x) 和 sb.insert(sb.length(), x) 具有相同的效果。 每个字符串生成器都有一定的容量。只要字符串生成器所包含的字符序列的长度没有超出此容量,就无需分配新的内部缓冲区。如果内部缓冲区溢出,则此容量自动增大。 将StringBuilder的实例用于多个线程是不安全的。如果需要这样的同步,则建议使用StringBuffer。[1]StringBuilder类可以用于在无需创建一个新的字符串对象情况下修改字符串。StringBuilder不是线程安全的,而StringBuffer是线程安全的,但其在单线程中的性能比StringBuffer高。
参考文章: