String,StringBuffer,StringBuilder

关于StringBuffer 和 StringBuilder的使用

String,StringBuffer,StringBuilder的异同

String : 不可变字符序列,底层使用char[]存储
StringBuffer : 可变字符序列,线程安全的,效率低,底层使用char[]存储
StringBuilder : 可变的字符序列,jdk5.0新增的,线程不安全的,效率高,底层使用char[]存储

源码分析:

String str = new String();//char[] value = new char[0];
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[0] = 'a';
	sb1.append('b');//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) 或 StringBuilder(int capacity)

@Test
    public void test1(){
        StringBuffer sb1 = new StringBuffer("abc");
        sb1.setCharAt(1,'m');
        System.out.println(sb1);

        StringBuffer sb2 = new StringBuffer();
        System.out.println(sb2.length());//0
    }

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 setCharAt(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() / toString()

这里以StringBuffer为例 ,但StringBuffer和StringBuilder下的方法都一样

    @Test
    public void test2(){
        StringBuffer s1 = new StringBuffer("abc");
        s1.append( 1 );
        System.out.println(s1);//abc1

        StringBuffer sb2 = new StringBuffer( "huanhuan" );
        sb2.delete( 1,4 );
        System.out.println(sb2); //hhuan

        sb2.replace( 0,1,"hao" ); //将上方的h 替换成hao
        System.out.println(sb2); //haohuan

        s1.insert( 4 , "defg");
        System.out.println(s1);

        System.out.println(s1.reverse()); //gfed1cba
        System.out.println(s1.indexOf("e")); //2

        StringBuffer sb3 = new StringBuffer( "haoge" );
        String substring = sb3.substring( 0, 3 ); //[0,3)
        System.out.println(substring); //hao

        System.out.println( sb3.length() ); //5
    }

String ,StringBuffer,StringBuilder 效率对比

/**
     * 对比String、StringBuffer、StringBuilder三者的效率:
     * 从高到低排列:StringBuilder > StringBuffer > String
     */
    @Test
    public void test1() {
        //初始设置
        long startTime = 0L;
        long endTime = 0L;
        String text = "";
        StringBuffer buffer = new StringBuffer( "" );
        StringBuilder builder = new StringBuilder( "" );
        //开始对比
        startTime = System.currentTimeMillis();
        for (int i = 0; i < 20000; i++) {
            buffer.append( String.valueOf( i ) );
        }

        endTime = System.currentTimeMillis();
        System.out.println( "StringBuffer的执行时间:" + (endTime - startTime) );
        startTime = System.currentTimeMillis();
        for (int i = 0; i < 20000; i++) {
            builder.append( String.valueOf( i ) );
        }

        endTime = System.currentTimeMillis();
        System.out.println( "StringBuilder的执行时间:" + (endTime - startTime) );
        startTime = System.currentTimeMillis();
        for (int i = 0; i < 20000; i++) {
            text = text + i;
        }

        endTime = System.currentTimeMillis();
        System.out.println( "String的执行时间:" + (endTime - startTime) );
    }

结果如下:从高到低排列:StringBuilder > StringBuffer > String

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值