天天看點

String類的詳細介紹和Stringbuffer、Stringbuilder 類的簡單介紹

String類的詳細介紹和Stringbuffer、Stringbuilder 類的簡單介紹

String類

一、擷取

  1.1:字元串中包含的字元數,也就是字元串的長度。

  int length():擷取長度

 1.2:根據位置擷取位置上某個字元。

  char charAt(int index)

 1.3:根據字元擷取該字元在字元串中的位置。

int indexOf(int ch):傳回的是ch在字元串中第一次出現的位置。

  int indexOf(int ch,int fromIndex):從fromIndex指定位置開始,擷取ch在字元串中出現的位置。

  int indexOf(String str):傳回的是str在字元串中第一次出現的位置。

  int indexOf(String str,int fromIndex):從fromIndex指定位置開始,擷取str在字元串中出現的位置。

 1.4:int lastIndexOf(String str):反向索引。

二、判斷

2.1:字元串中是否包含某一個子串。

      boolean contains(str);

   特殊之處:indexOf(str):可以索引str第一次出現為止,如果傳回-1,表示該str不在字元串中存在。 是以,也可以用于對指定判斷是否包含。

    if(str.indexOf("a")!=1)   而且該方法既可以判斷,也可以擷取出現的位置。

 2.2:字元串中是否有内容。

    boolean isEmpty():原理就是判斷長度是否為0。

 2.3:字元串是否以指定内容開頭。

   boolean startsWith(str);

 2.4:字元串是否以指定内容結尾。

   boolean endsWith(str);

 2.5:判斷字元内容是否相同,複寫了object類中的equals方法。

   boolean equals(str);

 2.6:判斷内容是否相同,并忽略大小寫。

  boolean.equalsIgnorecase();

三、轉換

 3.1:将字元數組轉成字元串。

  構造函數:String(char[])

      String(char[],offset,count):将字元數組中的一部分轉成字元串

   靜态方法:

     static String copyValueOf(char[]);

     static String copyValueOf(char[] data,int offset,int count);

     static String valueOf(char[]);

 3.2:将字元串轉成字元組

  char[] tocharArray();

 3.3:将位元組數組轉成字元串。

      String(byte[])

     String(byte[],offset,count):将位元組數組中的一部分轉成字元串

 3.4:将字元串轉成位元組數組。

  byte[] getBytes()

 3.5:将基本資料類型轉成字元串,

 static String valueOf(int)

 static String valueOf(double)

 // 3+"" 與 String.valueOf(3)的值是一樣的

 特殊:字元串和位元組數組在轉換過程中,是可以指定編碼的。

四、替換

 String replace(oldchar,newchar);

5>切割

 String[] split(regex);

6>子串。擷取字元串中的而一部分

 String subString(begin);

 String subString(begin,end);

7>轉換,去除空格,比較。 

 7.1:将字元串轉成大寫或小寫

   String toUpperCsae() 大轉小

   String toLowerCsae() 小轉大

 7.2:将字元串兩端的多個空格去除

   String trim();

 7.3:對兩個字元串進行自然順序的比較

   int compareTo(string);

五、示例展示

 請看如下代碼,下面的代碼都是針對上面string七種用法而進行一一舉例說明:

代碼如下:

class StringMethodDemo 
{
 public staticvoid method_Zhuanhuan_Qukong_Bijiao() {
    String s ="     hello Java    ";
    System.out.println(s);//列印結果是:(hello和java前後門都有空格)hello java
    System.out.println(s.toUpperCase());//列印結果是:(HELLO和JAVA前後門都有空格)HELLO JAVA
    System.out.println(s.toLowerCase());//列印及結果是:帶空格的“hello java”
    System.out.println(s.trim());//列印及結果是:不帶空格的“hello java”
    String s1 = "abc";
    String s2 ="aaa";
    System.out.println(s1.compareTo(s2)); //比較數的大寫,列印結果是:1,因為b對應ascii值是98,//a對應是97,是以b-a=1
 }
 public static void method_sub() {
    String s ="abcdef";
    System.out.println(s.substring(2)); //列印結果是:cdef,從指定位置開始到結尾。如果角标不存在,會出現字元串角标越界。
    System.out.println(s.substring(2,4)); //列印結果是:cd,包含頭,不包含尾。
 }
 public staticvoid method_split() {
    String s ="zhangsan,lisi,wangwu";
    String[] arr = s.split(",");//以,為分割,分割成數組3個3個值
    for(int x=0; x<arr.length; x++)  {
        System.out.println(arr[x]);//分别輸出zhangsan  lisi  wangwu 
    }
 }
 public static void method_replace() {
    String s ="hello java";
    //String s1 = s.replace('a','n'); //把a 替換為n
    //String s1 = s.replace('w','n');  //如果要替換的字元不存在,傳回的還是原串

     String s1 = s.replace("java","world");//把java 替換為world
     System.out.println("s="+s); //列印結果是:hello java因為字元串一旦被初始化,值就不可被改變
     System.out.println("s1="+s1);//列印結果是:hello jnvn
 }
 public static void method_trans() {
    char[] arr ={'a','b','c','d','e','f'};
    String s = new  String(arr,1,3);
    System.out.println("s="+s);//列印結果是:bcd
    String s1 = "zxcvbnm";
    char[] chs =s1.toCharArray();
    for(int x=0; x<chs.length; x++) {
         System.out.println("ch="+chs[x]);//列印結果是:ch=z,x,c,v,b,n,m
    }
 }
 public static void method_is() {
     String str ="ArrayDemo.java";//下面的判斷對的就傳回true否則傳回false
     System.out.println(str.startsWith("Array"));//判斷檔案名稱是否是Array單詞開頭

     System.out.println(str.endsWith(".java"));//判斷檔案名稱是否是.java的檔案
     System.out.println(str.contains("Demo"));//判斷檔案中是否包含Demo
 }
 
 public static void method_get() {
     String str ="abcdeakpf";
     System.out.println(str.length());//長度
     System.out.println(str.charAt(4)); //根據索引擷取字元
  //System.out.println(str.charAt(40));當通路到字元串中不存在的角标時會發生StringIndexOutOfBoundsException(字元串角标越界異常)
     //根據字元擷取索引
     System.out.println(str.indexOf('a')); //輸出0
     System.out.println(str.indexOf('a',3));// /輸出列印的是5,因為角标3是d,
     //是以從d後面開始找a,第5個角标是a
     //System.out.println(str.indexOf('t',3))列印:-1,如果沒有找到角标,傳回-1
     System.out.println(str.lastIndexOf("a")); //反向索引一個字元出現的位置(從右往左查找,但是角标還是從左開始),輸出還是5

 }
 public static void main(String[] args)  {
    method_Zhuanhuan_Qukong_Bijiao();
    //method_sub();
    //method_split();
    //method_replace();  
    //method_trans(); 
     //method_is();
    //method_get();
      /*
      String s1 ="abc";
      String s2 =new String("abc");
      String s3 = "abc";
     System.out.println(s1==s2);//輸出false
      System.out.println(s1==s3); //輸出true
    
      */
    }
 }
           

六、Stringbuffer類和Stringbuilder類

String 字元串常量

StringBuffer 字元串變量(線程安全)

StringBuilder 字元串變量(非線程安全)

 簡要的說, String類型和 StringBuffer 類型的主要性能差別其實在于 String 是不可變的對象, 是以在每次對 String 類型進行改變的時候其實都等同于生成了一個新的 String 對象,然後将指針指向新的 String 對象,是以經常改變内容的字元串最好不要用 String ,因為每次生成對象都會對系統性能産生影響,特别當記憶體中無引用對象多了以後, JVM 的 GC 就會開始工作,那速度是一定會相當慢的。

buffer是緩存的意思,builder是建設的意思

StringBuffer和StringBuilder使用的方法是一樣的

StringBuffer 是線程安全的 StringBuilder是線程不安全的

怎麼了解Stringbuffer 是線程安全的 stringbuilder是線程不安全的

1、 多個線程操作同一個StringBuffer對象會順序進行(内部很多方法是同步方法)

2、多個線程操作同一個StringBuilder是同時的,這時候可能出現與預期不符合的結果

3、StringBuilder由于是線程不安全的,是以性能更好。

4、大部分情況下都是單線程操作字元串,這時候選擇StringBuilder。  

速度比較:StringBuilder速度較快           StringBuffer相對較慢

七、StringBuffer和StringBuilder的一些使用的方法

重要的是append()和inset(),這兩個在java都沒有

append的使用

StringBuilder sb = new StringBuilder(“”);//不能像String直接用雙引号定義變量,這裡需要new出來

sb.Append( "123456789" );//添加一個字元串

sb.Length = 3;//設定容量為3

System.out.println ( sb.toString() );//這裡輸出:123

sb.Length = 30;//重新設定容量為30

System.out.println ( sb.ToString() + ",結尾");//這裡在原來字元串後面補齊空格,至到Length的為30

System.out.println ( sb.Length );//這裡輸出的長度為30

insert的使用

public static void main(String[] args){

double d=1234.5;

     //double先轉換為String類型,再轉換為StringBuffer類型

    StringBuffer sb=new StringBuffer(d+"");

    for (inti = sb.indexOf(".")-3;i > 0; i-=3) {

        sb.insert(i,",");

    }

    System.out.println(“d=”+d);//輸出d=1,234.5

}

用一個例子來看StringBuilder和String之間的速度差距:

public class StringTest {
 
    // String類和StringBuffer速度的比較
    public static void main(String[] args) {
       StringBuffer sb = new StringBuffer ("");//建立Stringbuffer對象,并執行個體化
       int i = 0;
       long StartTime = System.currentTimeMillis();//擷取系統循環執行開始時間的毫秒數
       while (i <100000) {
           sb.append((i + "").toString());//使用append方法
           i++;
       }
       long EndTime = System.currentTimeMillis();//擷取系統循環執行結束時間的毫秒數
       System.out.println("StringBuffer時間:" + (EndTime - StartTime));//計算時間差
      
       String sb1 = "";//建立String對象
       i = 0;
       StartTime = System.currentTimeMillis();//擷取系統循環執行開始時間的毫秒數
       while (i <100000) {
           sb1 = sb1 + i;//和append效果一樣
           i++;
       }
       EndTime = System.currentTimeMillis();//擷取系統循環執行結束時間的毫秒數
       System.out.println("String時間:" + (EndTime - StartTime));//計算時間差
    }
}
           

 運作結果:

String類的詳細介紹和Stringbuffer、Stringbuilder 類的簡單介紹

運作結果相差很大哦!

是以StringBuilder和StringBuffer用于變量經常改變的情況,運作速度很快,

但是其他情況還是比較多使用String這個類的!