一:对比string、StringBuffer、StringBuilder三者的效率:
从高到低排列: StringBuilder > StringBuffer > String
二:
StringBuffer的常用方法: StringBuffer append(xxx):提供了很多的append()方法,用于进行字符串拼接 StringBuffer delete(int start, int end):删除指定位置的内容 StringBuffer replace(int start, int end, String str):把[start,end)位置替换为str StringBuffer insert(int offset, xxx):在指定位置插入xXx StringBuffer reverse():把当前字符序列逆转 public int indexOf(string str) public String substring(int start,int end)返回一个从start开始到end索引结束的左闭右开的子字符串 public int length() public char charAt(int n ) public void set CharAt(int n ,char ch) 总结: 增: append(xxx) 删: delete(int start,int end) 改: setCharAt(int n ,char ch) / replace(int start, int end,string str)查: charAt(int n ) 插: insert(int offset,xxX)长度: Length(); *遍历: for()+charAt()
三:
String StringBuffer,StringBuilder的异同 String:不可变的字符序列:底层用char[]数组存储 StringBuffer:可变的字符序列:线程安全,效率底,底层用char[]数组存储 StringBuilder:jdk5.0新增,可变的字符序列:线程不安全,效率高,底层用char[]数组存储 源码分析: String str = new String();//char[] value = new char[e]; string str1 = new String("abc");//char[] value = new char[]{ 'a' , ' b' , ' c'}; stringBuffer sb1 = new StringBuffer();//char[]value = new char[16];底层创建了一个长度是16数组 system.out. println( sb1.length());//sb1.append( 'a' ); //value[e] = 'a ';sb1.append( ' b'); l/value[1] = 'b '; StringBuffer sb2 = new StringBuffer("abc");//char[] value = new char["abc".length() + 16]; 问题1.System.out.printLn(sb2.Length() );//3 问题2.扩容问题:如果要添加的数据底层数组盛不下了,那就需要扩容底层的数组。 默认情况下,扩容为原来容量的2倍+2,同时将原有数组中的元素复制到新的数组中。 指导意义:开发中建议大家使用:StringBuffer(int capacity)或 StringBuffer(int capacity)