<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ThinkChat2.0新版上線,更智能更精彩,支持會話、畫圖、視頻、閱讀、搜索等,送10W Token,即刻開啟你的AI之旅 廣告
                [TOC] # java的API Object類是Java語言中的根類,即所有類的父類。它中描述的所有方法子類都可以使用。所有類在創建對象的時候,最終找的父類就是Object。object類有構造方法 接口不繼承object類 ## equals equals方法,用于比較兩個對象是否相同,它其實就是使用兩個對象的內存地址在比較。Object類中的equals方法內部使用的就是==比較運算符。 ~~~ /* 描述人這個類,并定義功能根據年齡判斷是否是同齡人 由于要根據指定類的屬性進行比較,這時只要覆蓋Object中的equals方法 在方法體中根據類的屬性值進行比較 */ class Person extends Object{ int age ; //復寫父類的equals方法,實現自己的比較方式 public boolean equals(Object obj) { //判斷當前調用equals方法的對象和傳遞進來的對象是否是同一個 if(this == obj){ return true; } //判斷傳遞進來的對象是否是Person類型 if(!(obj instanceof Person)){ return false; } //將obj向下轉型為Perosn引用,訪問其屬性 Person p = (Person)obj; return this.age == p.age; } } ~~~ 注意:在復寫Object中的equals方法時,一定要注意public boolean equals(Object obj)的參數是Object類型,在調用對象的屬性時,一定要進行類型轉換,在轉換之前必須進行類型判斷。 ## toString toString方法返回該對象的字符串表示,其實該字符串內容就是對象的類型+@+內存地址值。 由于toString方法返回的結果是內存地址,而在開發中,經常需要按照對象的屬性得到相應的字符串表現形式,因此也需要重寫它。 ~~~ class Person extends Object{ int age ; //根據Person類的屬性重寫toString方法 public String toString() { return "Person [age=" + age + "]"; } } ~~~ # string類 查閱API中的String類的描述,發現String 類代表字符串。Java 程序中的所有字符串字面值(如 "abc" )都作為此類的實例實現。 ~~~ //演示字符串 String str = "abc"; str = "ef"; ~~~ 字符串是常量;它們的值在創建之后不能更改,這是什么意思呢?其實就是說一旦這個字符串確定了,那么就會在內存區域中就生成了這個字符串。字符串本身不能改變,但str變量中記錄的地址值是可以改變的 字符串有大量的重載的構造方法。通過String類的構造方法可以完成字符串對象的創建,那么,通過使用雙引號的方式創建對象與new的方式創建對象,有什么不同呢?看如下程序與圖解: ~~~ String s3 = "abc"; String s4 = new String("abc"); System.out.println(s3==s4);//false System.out.println(s3.equals(s4));//true, //因為String重寫了equals方法,建立了字符串自己的判斷相同的依據(通過字符串對象中的字符來判斷) ~~~ s3和s4的創建方式有什么不同呢? * s3創建,在內存中只有一個對象。這個對象在字符串常量池中 * s4創建,在內存中有兩個對象。一個new的對象在堆中,一個字符串本身對象,在字符串常量池中 # 字符串緩沖區 StringBuffer類 StringBuffer又稱為可變字符序列,它是一個類似于 String 的字符串緩沖區,通過某些方法調用可以改變該序列的長度和內容 StringBuffer是個字符串的緩沖區,即就是它是一個容器,容器中可以裝很多字符串。并且能夠對其中的字符串進行各種操作 # StringBuilder類 StringBuilder類,它也是字符串緩沖區,StringBuilder與它和StringBuffer的有什么不同呢? 我們閱讀StringBuilder的API說明發現,它也是一個可變的字符序列。此類提供一個與 StringBuffer 兼容的 API,但不保證同步。該類被設計用作 StringBuffer 的一個簡易替換,用在字符串緩沖區被單個線程使用的時候(這種情況很普遍)。如果可能,建議優先采用該類,因為在大多數實現中,它比 StringBuffer 要快。 # 總結 * Object: 它是所有類的超類,祖宗類。java中所有的類都直接或間接的繼承這個類 - 方法 public String toString() 返回當前對象中的內容, 對于Object類默認操作來說,返回的對象的類型+@+內存地址值 public boolean equals(Object obj) 比較兩個對象內容是否相同,對于Object類默認操作來說,比較的是地址值 * String: 字符串類,字符串是常量;它們的值在創建之后不能更改 - 方法 boolean equals(Object obj) 判斷兩個字符串中的內容是否相同 boolean equalsIgnoreCase(String str) 判斷兩個字符串中的內容是否相同, 忽略大小寫 boolean contains(String str) 判斷該字符串中 是否包含給定的字符串 boolean startsWith(String str) 判斷該字符串 是否以給定的字符串開頭 boolean endsWith(String str) 判斷該字符串 是否以給定的字符串結尾 boolean isEmpty() 判斷該字符串的內容是否為空的字符串 "" int length() 獲取該字符串的長度 char charAt(int index) 獲取該字符串中指定位置上的字符 String substring(int start) 從指定位置開始,到末尾結束,截取該字符串,返回新字符串 String substring(int start,int end) 從指定位置開始,到指定位置結束,截取該字符串,返回新字符串 int indexOf(int chr ) 獲取給定的字符,在該字符串中第一次出現的位置 int indexOf(String str) 獲取給定的字符串,在該字符串中第一次出現的位置 int indexOf(int chr,int fromIndex) 從指定位置開始,獲取給定的字符,在該字符 byte[] getBytes() 把該字符串 轉換成 字節數組 char[] toCharArray() 把該字符串 轉換成 字符數組 String replace(char old,char new) 在該字符串中,將給定的舊字符,用新字符替換 String replace(String old,String new) 在該字符串中, 將給定的舊字符串,用新字符串替換 String trim() 去除字符串兩端空格,中間的不會去除,返回一個新字符串 String toLowerCase() 把該字符串轉換成 小寫字符串 String toUpperCase() 把該字符串轉換成 大寫字符串 int indexOf(String str,int fromIndex) 從指定位置開始,獲取給定的字符串,在該字符串中第一次出現的位置 * StringBuffer/StringBuilder: - 方法 public StringBuffer append(String str) 在原有字符串緩沖區內容基礎上,在末尾追加新數據 public StringBuffer insert(int offset,String str) 在原有字符串緩沖區內容基礎上,在指定位置插入新數據 public StringBuffer deleteCharAt(int index) 在原有字符串緩沖區內容基礎上,刪除指定位置上的字符 public StringBuffer delete(int start,int end) 在原有字符串緩沖區內容基礎上,刪除指定范圍內的多個字符 public StringBuffer replace(int start,int end,String str)在原有字符串緩沖區內容基礎上,將指定范圍內的多個字符 用給定的字符串替換 public StringBuffer reverse() 將字符串緩沖區的內容 反轉 "abc"----"cba" public String substring(int start) 從指定位置開始,到末尾結束,截取該字符串緩沖區,返回新字符串 public String substring(int start,int end) 從指定位置開始,到指定位置結束,截取該字符串緩沖區,返回新字符串 創建一個字符串緩沖區對象。用于存儲數據。 ~~~ StringBuffer sb = new StringBuffer(); sb.append("haha"); //添加字符串 sb.insert(2, "it");//在指定位置插入 sb.delete(1, 4);//刪除 sb.replace(1, 4, "cast");//替換指定范圍內的內容 String str = sb.toString(); ~~~ 注意:append、delete、insert、replace、reverse方法調用后,返回值都是當前對象自己,所以說,StringBuffer它可以改變字符序列的長度和內容
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看