Java核心API -- 2(String、StringBuilder、StringBuffer)

 

1. String字符串java

    1)String類型介紹數組

        String類採用final修飾,String對象爲不可變對象,一旦在內存中建立,內容不能發生變化,若要對字符串內容改變,那麼就會建立新對象。安全

        String對象建立,有靜態和動態之分。app

        String str1 = "dadsadad";ide

        String str2 = new String("dasdasdadad");ui

    2)String常量池spa

        JVM對字符串有一個限制,讓字符串做爲不變對象,這樣就能夠作到重用。事實上,當咱們經過字面量,常量來初始化一個字符串時,JVM首先會從字符串的常量池(一個JVM內部維護的內存區域,用來保存已經建立過的字符串對象)中查詢用來保存該字符串的對象是否存在,若存在則直接引用,若不存在則建立該字符串對象並存入常量池,而後引用它。線程

    3)字符串的經常使用方法設計

        String str = "dn1aAj2FD6hbF4hjaX0f";orm

        ① str.length(),獲取字符串的長度,返回int類型的數值

        ② str.indexOf(char c),獲取字符串中某個字符第一次出現的索引,找不到,返回值爲-1。    

            str.lastIndexOf(char c), 返回指定字符在此字符串中最後一次出現的索引,找不到,返回值爲-1

        ③ str.charAt(int index),獲取字符串指定下標位置上的字符,返回值是char類型的。

        ④ str.toUpperCase(),將字符串str所有轉成大寫,

            str.toLowerCase(),將字符串str所有轉成小寫,返回的都是新的字符串。

        ⑤ str.stratsWith(String s),判斷字符串str是否是以字符串s開頭,

            str.endsWith(String s),判斷字符串str是否是以s結尾,返回值都是boolean類型的。

        ⑥ str.equals(String s),判斷兩個字符串的內容是否相等(在前一章已經分析了==和equals()的區別了),返回boolean類型。

        ⑦ str.replace(char oldChar, char newChar):將字符串中匹配odChar的字符所有替換成新的newChar字符,返回新的字符串。

        ⑧ str.subString(int begin),截取字符串中某一段字符,從下標begin開始,截取到最後, 

            str.subString(int begin, int end),截取字符串中某一段字符,從下標begin開始,到end-1結束,返回的是一個新的字符串。

        ⑨  str.split(String regex): 參數regex爲一個字符串規則,以regex所表示的字符串爲分隔符,將字符串拆分紅字符串數組。

            其中,regex所表示的字符串不被保留,即 不會存到字符串數組中,可理解爲被一刀切,消失!

        ⑩ str.trim(),去掉字符串先後兩端的空格,返回新的字符串。


    案例1:

        wKiom1VpXFuQqmBrAASwtINybJQ543.jpg

    結果:

        wKiom1VpXDLi6RVTAAC6ccQzdhE717.jpg



2. StringBuilder、StringBuffer類

    String類咱們已經得知,它是不變對象,那麼每當對內容修改時都會引起新對象的建立。那麼當咱們有一個需求是須要頻繁修改字符串時,這樣不只不能減小內存的開銷,返回會增長內存的開銷。爲此java爲咱們提供了一個專門用於修改字符串內容的類StringBuilder類, 該類封裝了可變的字符串,換句話說,當咱們須要改變字符串內容時,並不會建立新對象,而是在原對象基礎上進行修改。從而減少了內存的開銷。

    StringBuilder類的經常使用方法有:

        append(String str):追加字符串;

        insert (int index,String s):從指定下標位置插入字符串;

        delete(int start,int end):從起始下標刪除字符串到end結束下標,end要大於等於start,能夠超出數組總長度;

        replace(int start,int end,String str): 替換字符串;

        reverse():字符串反轉。


    案例2:

        wKioL1VpXk6S6Kt1AAIdeTsMaoA374.jpg

    結果:能夠看出效率方面對比性很強。

        wKioL1VpXmHy_MRRAAAgWGN4fow859.jpg


    案例3:

        wKioL1VpXoGhgIPKAAG5xr3Z9I4780.jpg

    結果:

        wKiom1VpXQ3ybtGkAABDwASbl9U071.jpg


    StringBuffer類,是JDK早期的版本,StringBuffer是線程安全的可變字符序列。雖然在任意時間點上它都包含某種特定的字符序列,但經過某些方法調用能夠改變該序列的長度和內容。可將字符串緩衝區安全地用於多個線程。能夠在必要時對這些方法進行同步,所以任意特定實例上的全部操做就好像是以串行順序發生的,該順序與所涉及的每一個線程進行的方法調用順序一致。StringBuffer 上的主要操做是 append 和 insert 方法,可重載這些方法,以接受任意類型的數據。每一個方法都能有效地將給定的數據轉換成字符串,而後將該字符串的字符追加或插入到字符串緩衝區中。

    一般,若是 sb 引用 StringBuilder 的一個實例,則 sb.append(x) 和 sb.insert(sb.length(), x) 具備相同的效果。只要發生有關源序列(如在源序列中追加或插入)的操做,該類就只在執行此操做的字符串緩衝區上而不是在源上實現同步。每一個字符串緩衝區都有必定的容量。只要字符串緩衝區所包含的字符序列的長度沒有超出此容量,就無需分配新的內部緩衝區數組。若是內部緩衝區溢出,則此容量自動增大。

    從 JDK 5 開始,爲該類補充了一個單個線程使用的等價類,即 StringBuilder。與該類相比,一般應該優先使用 StringBuilder 類,由於它支持全部相同的操做,但因爲它不執行同步,因此速度更快。 java.lang.StringBuilder一個可變的字符序列。此類提供一個與 StringBuffer 兼容的 API,但不保證同步。該類被設計用做 StringBuffer 的一個簡易替換,用在字符串緩衝區被單個線程使用的時候(這種狀況很廣泛)。若是可能,建議優先採用該類,由於在大多數實現中,它比 StringBuffer 要快。

相關文章
相關標籤/搜索