String和StringBuffer详解

String s = new String(new StringBuffer("abc"))

(2005-02-26 01:01:00)
标签:

杂谈

 

问题:在String对象中有个构造函数是直接接受StringBuffer的。程序如下:

   public String (StringBufferbuffer) {
       synchronized(buffer) {
           buffer.setShared();
           this.value = buffer.getValue();
           this.offset = 0;
           this.count = buffer.length();
       }
   }

在StringBuffer中:

    final char[] getValue() { return value;}

很明显的,这个构造函数直接把StringBuffer的char[]数组返回给了String对象。也就是现在新生成的String和StringBuffer共用同一个char[]数组,但是下面的程序为什么会打印出以下结果呢:

   StringBuffer sb = new StringBuffer("abc");
   System.out.println("StringBuffer: " +sb.toString());
    String s =new String(sb);
   System.out.println("String: " + s);
   sb.append("123");
   System.out.println("StringBuffer: " + sb);
   System.out.println("String: " + s);
   /
   StringBuffer: abc
   String: abc
   StringBuffer: abc123
   String: abc

分析:这个问题的核心答案在 this.count =buffer.length()这句话上。这句话的意思是String中的count的大小为这个char[]数组中实际含有的字符的个数,而不是这个数组的大小。所以在打印的时候对于上面的String对象,只会打印3个字符,而不是六个字符!!

新的问题:如果我从StringBuffer中删除了一个字符,那么String对象也应该受到影响了?但是为什么实际上这个String没有发生变化呢?问题的答案在buffer.setShared()上,这句话的含义就是告诉这个StringBuffer,有其它的String对象与它共享它的char[]数组。这个时候,当它进行delete,insert等操作的时候,它会新生成一个char[]数组,然后再进行操作。所以这个时候String和StringBuffer就不共享同一个数组了,String自然也就不会受到影响了。

为什么要用这么复杂的方法呢?答案是“节省内存资源”。可以想想,我们在程序中使用最频繁的对象都有哪些?答案肯定包含String。而我们知道,在拼装一个String的时候,使用StringBuffer效率最高。所以我们会先用StringBuffer动态的拼装好一个字符串,然后再把它转化成String对象,这个时候就会突显这种方式的经典之处了。下面是StringBuffer的toString()方法:

    publicString toString() {
       return new String(this);
   }


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值