zoukankan      html  css  js  c++  java
  • Java中的StringBuffer

    简介: 

    String和StringBuffer都可以存储和操作字符串,即包含多个字符的字符串数据。他们的区别就是String类是字符串常量,是不可更改的常量。而StringBuffer是字符串变量,它的对象是可以扩充和修改的。简要的说, String 类型和 StringBuffer 类型的主要性能区别其实在于 String 是不可变的对象, 因此在每次对 String 类型进行改变的时候其实都等同于生成了一个新的 String 对象,然后将指针指向新的 String 对象,所以经常改变内容的字符串最好不要用 String ,因为每次生成对象都会对系统性能产生影响,特别当内存中无引用对象多了以后, JVM 的 GC 就会开始工作,那速度是一定会相当慢的。

       而如果是使用 StringBuffer 类则结果就不一样了,每次结果都会对 StringBuffer 对象本身进行操作,而不是生成新的对象,再改变对象引用。所以在一般情况下我们推荐使用 StringBuffer ,特别是字符串对象经常改变的情况下。而在某些特别情况下, String 对象的字符串拼接其实是被 JVM 解释成了 StringBuffer 对象的拼接,所以这些时候 String 对象的速度并不会比 StringBuffer 对象慢,而特别是以下的字符串对象生成中, String 效率是远要比 StringBuffer 快的:
     String S1 = “This is only a” + “ simple” + “ test”;
     StringBuffer Sb = new StringBuilder(“This is only a”).append(“ simple”).append(“ test”);
     你会很惊讶的发现,生成 String S1 对象的速度简直太快了,而这个时候 StringBuffer 居然速度上根本一点都不占优势。其实这是 JVM 的一个把戏,在 JVM 眼里,这个
       String S1 = “This is only a” + “ simple” + “test”; 其实就是:
       String S1 = “This is only a simple test”; 所以当然不需要太多的时间了。但大家这里要注意的是,如果你的字符串是来自另外的 String 对象的话,速度就没那么快了,譬如:
      String S2 = “This is only a”;
      String S3 = “ simple”;
      String S4 = “ test”;
      String S1 = S2 +S3 + S4;
    这时候 JVM 会规规矩矩的按照原来的方式去做
    StringBuffer
    Java.lang.StringBuffer线程安全的可变字符序列。一个类似于 String 的字符串缓冲区,但不能修改。虽然在任意时间点上它都包含某种特定的字符序列,但通过某些方法调用可以改变该序列的长度和内容。
    可将字符串缓冲区安全地用于多个线程。可以在必要时对这些方法进行同步,因此任意特定实例上的所有操作就好像是以串行顺序发生的,该顺序与所涉及的每个线程进行的方法调用顺序一致。
    StringBuffer 上的主要操作是 append 和 insert 方法,可重载这些方法,以接受任意类型的数据。每个方法都能有效地将给定的数据转换成字符串,然后将该字符串的字符追加或插入到字符串缓冲区中。append 方法始终将这些字符添加到缓冲区的末端;而 insert 方法则在指定的点添加字符。
    例如,如果 z 引用一个当前内容是“start”的字符串缓冲区对象,则此方法调用 z.append("le") 会使字符串缓冲区包含“startle”,而 z.insert(4, "le") 将更改字符串缓冲区,使之包含“starlet”。
    方法:

    StringBuffer类的构造函数:public StringBuffer():创建一个空的StringBuffer类的对象。

                  public StringBuffer(int length): 创建一个长度为length的StringBuffer类的对象(注意:如果参数小于零,将触发NegativeArraySizeException异常。)。

      public StringBuffer(String str)用一个已有的String创建StringBuffer类的对象。

    方法:

      (1)StringBuffer append(Type t):向字符串缓冲区追加Type类型的元素t,t可以是布尔量、字符、字符数组、双精度数、浮点数、整型数、长整型数对象类型的字符串、字符串和StringBuffer类等。如果添加的字符串超出了字符串缓冲区的长度,Java将自动进行扩充。

      (2)int capacity():返回当前StringBuffer对象的总空间,而非字符创号的长度。

      (3)char cahrAt(int index):在当前StringBuffer对象中索引号为index的字符。第一个索引为0。

      (4)StringBuffer delete(int start, int end):删除当前StringBuffer对象中以索引号start开始,到end结束的子串。

      (5)StringBuffer deleteCharAt(int index):删除当前StringBuffer对象中索引号为index的字符。

      (6)void ensureCapacity (int minimumCapacity):重新设置字符号串缓冲区的总空间。如果minimumCapacity大于当前的总空间,则新的空间被设置:一种结果是minimumCapacity;另一种结果是{“老空间”乘2加2}。

      (7)void getChars(int srcBegin, int srcEnd, char[] dst, int dstBegin):从当前StringBuffer对象的索引号srcBegin开始,到srcEnd结束的子串,赋值到字符数组dst中,并且从dst的索引号dstBegin开始。

      (8)int indexOf(String str):返回当前StringBuffer对象中,第一个满足str子串的位置。

      (9)int indexOf(String str, int fromIndex):从当前StringBuffer对象的fromIndex开始查找,返回第一个满足str子串的位置。

      (10)StringBuffer insert(int offset, Type t):这些方法都是在当前StringBuffer对象中插入一个Type类型元素t,在索引号offset处插入t。

      (11)int lastIndexOf(String str):返回当前StringBuffer对象中,最后一个满足str子串的位置。

      (12)int lastIndexOf(String str, int fromIndex):从当前StringBuffer对象的fromIndex开始查找,返回最后一个满足str子串的位置。

      (13)int length():返回当前StringBuffer对象(字符缓冲区)中,字符串的长度。注意:此方法与capacity() 不同。

      (14)StringBuffer replace(int start, int end, String str):替换当前StringBuffer对象的字符串。从start开始,到end结束的位置替换成str。

      (15)StringBuffer reverse():将字符串翻转。

      (16)void setCharAt(int index, char ch):设置索引号index的字符为ch。

      (17)void setLength(int newLength):重新设置字符串缓冲区中字符串的长度,如果newLength小于当前的字符串长度,将截去多余的字符。

      (18)String substring(int start):取当前StringBuffer对象中,从start开始到结尾的子串。

      (19)String substring(int start, int end):取当前StringBuffer对象中,从start开始到end的子串。

      (20)String toString():将当前StringBuffer对象转换成String对象。

    简例: 

    public String toString()
      转换为String类对象并返回。由于大多数类中关于显示的方法的参数多为String类的对象,所以经常要将StringBuffer类的对象转换为String类的对象,再将它的值显示出来。用法如:
      StringBuffer sb=new StringBuffer("How are you?");
      Label l1=new Label(sb.toString());
      (注:声明一个标签对象l1,l1上的内容为How are you?)
      public StringBuffer append( boolean b )
      public StringBuffer append( char c )
      public StringBuffer append( int i)
      public StringBuffer append( long l )
      public StringBuffer append( float f )
      public StringBuffer append( double d )
      以上6个方法可将boolean、char、int、long、float和double 6种类型的变量追加到StringBuffer类的对象的后面。用法如:
      double d=123.4567;
      StringBuffer sb=new StringBuffer();
      sb.append(true);
      sb.append('c').append(d).append(99);
      (注:sb的值为truec123.456799)
      public StringBuffer append( String str )
      将字符串常量str追加到StringBuffer类的对象的后面。
      public StringBuffer append( char str[] )
      将字符数组str追加到StringBuffer类的对象的后面。
      public StringBuffer append
      ( char str[], int offset, int len )
      将字符数组str,从第offset个开始取len个字符,追加到StringBuffer类的对象的后面。
      public StringBuffer insert( int offset, boolean b )
      public StringBuffer insert( int offset, char c )
      public StringBuffer insert( int offset, int i )
      public StringBuffer insert( int offset, long l )
      public StringBuffer insert( int offset, float f )
      public StringBuffer insert( int offset, double d )
      public StringBuffer insert( int offset, String str )
      public StringBuffer insert( int offset, char str[] )
      将boolean、char、int、long、float、double类型的变量、String类的对象或字符数组插入到StringBuffer类的对象中的第offset个位置。用法如:
      StringBuffersb=new StringBuffer("abfg");
      sb.insert(2,"cde");
      (注:sb的值为abcdefg)
      public int length()
      这个方法返回字符串变量的长度,用法与String类的length方法类似。
      StringBuffer sbf=new StringBuffer();
      System.out.println(sbf.capacity());
      System.out.println(sbf.length());
      输出 16 ,0.
         默认构造器是由系统自动分配容量,默认是16个字符。由于没有赋值,所以缓冲对象的长度就是0.
      StringBuffer sbf=new StringBuffer(100);设定容量大小的构造器
      charAt()方法可以返回字符中的单个字符
      setCharAt(0,‘x’) 方法可以对字符中的单个字符进行替换
      reverse() 方法可以倒置字符串内容。
  • 相关阅读:
    mysql分组查询
    (三)分布式数据库tidb-隔离级别详解
    (二)分布式数据库tidb-事务
    (一)ArrayList集合源码解析
    (一)分布式数据库tidb-简介
    (二)LinkedList集合解析及手写集合
    电商数仓中需要统计的指标
    实时推荐模型的算法设计
    数据库需要掌握到什么程度可以应付工作?
    Mysql的万能优化方法
  • 原文地址:https://www.cnblogs.com/SoundCoder/p/7653414.html
Copyright © 2011-2022 走看看