<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 + "]"; } } ~~~ # 簡介 java.lang.String類代表字符串 java程序中所有的字符串字面值(比如: "abc")都是這個類的實現,就算沒有new也算是 **字符串特點** * 字符串內容永遠不可變 * 字符串可以共享使用 * 效果上相當于`char[]`字符數組,但是底層原理是`byte[]`字節數組 三種構造方法 ~~~ public String(): 創建一個空白字符串,不含有任何內容 public String(char[] array): 根據字符數組的內容來創建對應的字符串 public String(byte[] array): 根據字節數組的內容,來創建對應的字符串 一種直接創建 String str = "hello"; ~~~ # 例子 ~~~ //空參構造 String str1 = new String(); System.out.println("第一個字符串:" + str1); //根據字符數組創建字符串 char[] charArray = {'A', 'B', 'C'}; String str2 = new String(charArray); System.out.println("第二個字符串:" + str2); //根據字節數組創建字符串 byte[] byteArray = {97, 98, 99}; String str3 = new String(byteArray); System.out.println("第三個字符串:" + str3); ~~~ # 常量池 字符串常量池,程序中直接寫上的雙引號字符串就在字符串常量池中 ~~~ String str1 = "abc"; String str2 = "abc"; char[] charArray = {'a', 'b', 'c'}; String str3 = new String(charArray); System.out.println(str1 == str2); //true System.out.println(str1 == str3); //false System.out.println(str2 == str3); //false ~~~ 如果是字符數組的話,是常量池引用地址到字節數組的 ![](images/screenshot_1567934025057.png) ## 轉換編碼 ~~~ parameter = new String(parameter.getBytes("iso8859-1"),"utf-8"); ~~~ ## String類的特點 String類對象有兩種實例化方式: * 直接賦值: 只開辟一塊內存空間,可以自動入池 * 構造方法: 開辟兩塊堆內存空間,不會自動入池,使用intern()手工入池; 任何一個字符串都是String類的匿名對象 字符串一旦聲明則不可改變,可以改變的只是String類對象的引用 # 方法 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) 從指定位置開始,獲取給定的字符串,在該字符串中第一次出現的位置 ~~~ # intern 得到字符串對象后,通過調用intern(),判斷現有的字符串常量池中是否已經存在了當前內容的字符串. 如果存在,則直接引用現成的字符串 ~~~ String s1 = "hello"; String s3 = new String("hello"); //String s2 = s3.intern(); String s2 = s1.intern(); System.out.println(s1 == s2); //true System.out.println(s3 == s2); //false ~~~ 1. 直接定義字符串變量的時候賦值,如果表達式右邊只有字符串常量,那么就是把變量存放在常量池里面。 2. new出來的字符串是存放在堆里面。 3. 對字符串進行拼接操作,也就是做"+"運算的時候,分2中情況: i.表達式右邊是純字符串常量,那么存放在棧里面。 ii.表達式右邊如果存在字符串引用,也就是字符串對象的句柄,那么就存放在堆里面 # 字符串常量池 jdk6: 方法區(或永久代) jdk7: 堆空間 jdk8: 元空間 # 與其他結構的轉換 * String->包裝類: 調用包裝類`Xxxx`的`parseXxx(String s)`方法 * 包裝類,基本數據類型->string: 調用String的`valueOf(Xxx xxx);` * String與字節數組的轉換 ~~~ String->字節數組: 調用String類的getBytes() 字節數組->String: new String(byte[] buffer, startIndex, length) ~~~ * String與字符數組的轉換 ~~~ String->字符數組: 調用String類的toCharArray() 字符數組->String: new String(char[] cbuf, startIndex, length) ~~~
                  <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>

                              哎呀哎呀视频在线观看