天天看點

Java String

String : 字元串類型

一、構造函數

     String(byte[ ] bytes):通過byte數組構造字元串對象。

     String(char[ ] value):通過char數組構造字元串對象。

     String(Sting original):構造一個original的副本。即:拷貝一個original。

     String(StringBuffer buffer):通過StringBuffer數組構造字元串對象。  

例如:

      byte[] b = {'a','b','c','d','e','f','g','h','i','j'};

      char[] c = {'0','1','2','3','4','5','6','7','8','9'};

      String sb = new String(b);                 //abcdefghij

      String sb_sub = new String(b,3,2);     //de

      String sc = new String(c);                  //0123456789

      String sc_sub = new String(c,3,2);    //34

      String sb_copy = new String(sb);       //abcdefghij  

      System.out.println("sb:"+sb);

      System.out.println("sb_sub:"+sb_sub);

      System.out.println("sc:"+sc);

      System.out.println("sc_sub:"+sc_sub);

      System.out.println("sb_copy:"+sb_copy);

      輸出結果:sb:abcdefghij

                      sb_sub:de

                       sc:0123456789

                        sc_sub:34

                        sb_copy:abcdefghij

二、方法:

     說明:①、所有方法均為public。

           ②、書寫格式: [修飾符] <傳回類型><方法名([參數清單])>

      例如:static int parseInt(String s)

      表示此方法(parseInt)為類方法(static),傳回類型為(int),方法所需要為String類型。

1. char charAt(int index) :取字元串中的某一個字元,其中的參數index指的是字元串中序數。字元串的序數從0開始到length()-1 。

    例如:String s = new String("abcdefghijklmnopqrstuvwxyz");

          System.out.println("s.charAt(5): " + s.charAt(5) );

          結果為: s.charAt(5): f

2. int compareTo(String anotherString) :目前String對象與anotherString比較。相等關系傳回0;不相等時,從兩個字元串第0個字元開始比較,傳回第一個不相等的字元差,另一種情況,較長字元串的前面部分恰巧是較短的字元串,傳回它們的長度差。

3. int compareTo(Object o) :如果o是String對象,和2的功能一樣;否則抛出ClassCastException異常。

    例如:String s1 = new String("abcdefghijklmn");

            String s2 = new String("abcdefghij");

           String s3 = new String("abcdefghijalmn");

           System.out.println("s1.compareTo(s2): " + s1.compareTo(s2) ); //傳回長度差

           System.out.println("s1.compareTo(s3): " + s1.compareTo(s3) ); //傳回'k'-'a'的差

           結果為:s1.compareTo(s2): 4

                       s1.compareTo(s3): 10

4. String concat(String str) :将該String對象與str連接配接在一起。

5. boolean contentEquals(StringBuffer sb) :将該String對象與StringBuffer對象sb進行比較。

6. static String copyValueOf(char[] data) :

7. static String copyValueOf(char[] data, int offset, int count) :這兩個方法将char數組轉換成String,與其中一個構造函數類似。

8. boolean endsWith(String suffix) :該String對象是否以suffix結尾。

    例如:String s1 = new String("abcdefghij");

           String s2 = new String("ghij");

           System.out.println("s1.endsWith(s2): " + s1.endsWith(s2) );

           結果為:s1.endsWith(s2): true

9. boolean equals(Object anObject) :當anObject不為空并且與目前String對象一樣,傳回true;否則,傳回false。

10. byte[] getBytes() :将該String對象轉換成byte數組。

11. void getChars(int srcBegin, int srcEnd, char[] dst, int dstBegin) :該方法将字元串拷貝到字元數組中。其中,srcBegin為拷貝的起始位置、srcEnd為拷貝的結束位置、字元串數值dst為目标字元數組、dstBegin為目标字元數組的拷貝起始位置。

     例如:char[] s1 = {'I',' ','l','o','v','e',' ','h','e','r','!'};//s1=I love her!

           String s2 = new String("you!"); s2.getChars(0,3,s1,7); //s1=I love you!

           System.out.println( s1 );

           結果為:I love you!

12. int hashCode() :傳回目前字元的哈希表碼。

13. int indexOf(int ch) :隻找第一個比對字元位置。

14. int indexOf(int ch, int fromIndex) :從fromIndex開始找第一個比對字元位置。

15. int indexOf(String str) :隻找第一個比對字元串位置。

16. int indexOf(String str, int fromIndex) :從fromIndex開始找第一個比對字元串位置。

      例如:String s = new String("write once, run anywhere!");

              String ss = new String("run");

              System.out.println("s.indexOf('r'): " + s.indexOf('r') );

              System.out.println("s.indexOf('r',2): " + s.indexOf('r',2) );

              System.out.println("s.indexOf(ss): " + s.indexOf(ss) );

              結果為:s.indexOf('r'): 1

                      s.indexOf('r',2): 12

                      s.indexOf(ss): 12

17. int lastIndexOf(int ch)

18. int lastIndexOf(int ch, int fromIndex)

19. int lastIndexOf(String str)

20. int lastIndexOf(String str, int fromIndex) 以上四個方法與13、14、15、16類似,不同的是:找最後一個比對的内容。

public class CompareToDemo {

      public static void main (String[] args) {

           String s1 = new String("acbdebfg");

           System.out.println(s1.lastIndexOf((int)'b',7));

     }

}

運作結果:5

       (其中fromIndex的參數為 7,是從字元串acbdebfg的最後一個字元g開始往前數的位數。既是從字元c開始比對,尋找最後一個比對b的位置。是以結果為 5)

21. int length() :傳回目前字元串長度。

22. String replace(char oldChar, char newChar) :将字元号串中第一個oldChar替換成newChar。

23. boolean startsWith(String prefix) :該String對象是否以prefix開始。

24. boolean startsWith(String prefix, int toffset) :該String對象從toffset位置算起,是否以prefix開始。

     例如:String s = new String("write once, run anywhere!");

             String ss = new String("write");

             String sss = new String("once");

             System.out.println("s.startsWith(ss): " + s.startsWith(ss) );

             System.out.println("s.startsWith(sss,6): " + s.startsWith(sss,6) );

             結果為:s.startsWith(ss): true

                     s.startsWith(sss,6): true

25. String substring(int beginIndex) :取從beginIndex位置開始到結束的子字元串。

26.String substring(int beginIndex, int endIndex) :取從beginIndex位置開始到endIndex位置的子字元串。

27. char[ ] toCharArray() :将該String對象轉換成char數組。

28. String toLowerCase() :将字元串轉換成小寫。

29. String toUpperCase() :将字元串轉換成大寫。

     例如:String s = new String("java.lang.Class String");

             System.out.println("s.toUpperCase(): " + s.toUpperCase() );

             System.out.println("s.toLowerCase(): " + s.toLowerCase() );

             結果為:s.toUpperCase(): JAVA.LANG.CLASS STRING

                  s.toLowerCase(): java.lang.class string

30. static String valueOf(boolean b)

31. static String valueOf(char c)

32. static String valueOf(char[] data)

33. static String valueOf(char[] data, int offset, int count)

34. static String valueOf(double d)

35. static String valueOf(float f)

36. static String valueOf(int i)

37. static String valueOf(long l)

38. static String valueOf(Object obj)

     以上方法用于将各種不同類型轉換成Java字元型。這些都是類方法。

Java中String類的常用方法:

public char charAt(int index)

傳回字元串中第index個字元;

public int length()

傳回字元串的長度;

public int indexOf(String str)

傳回字元串中第一次出現str的位置;

public int indexOf(String str,int fromIndex)

傳回字元串從fromIndex開始第一次出現str的位置;

public boolean equalsIgnoreCase(String another)

比較字元串與another是否一樣(忽略大小寫);

public String replace(char oldchar,char newChar)

在字元串中用newChar字元替換oldChar字元

public boolean startsWith(String prefix)

判斷字元串是否以prefix字元串開頭;

public boolean endsWith(String suffix)

判斷一個字元串是否以suffix字元串結尾;

public String toUpperCase()

傳回一個字元串為該字元串的大寫形式;

public String toLowerCase()

傳回一個字元串為該字元串的小寫形式

public String substring(int beginIndex)

傳回該字元串從beginIndex開始到結尾的子字元串;

public String substring(int beginIndex,int endIndex)

傳回該字元串從beginIndex開始到endsIndex結尾的子字元串

public String trim()

傳回該字元串去掉開頭和結尾空格後的字元串

public String[] split(String regex)

将一個字元串按照指定的分隔符分隔,傳回分隔後的字元串數組

執行個體:  

public class SplitDemo{

     public static void main (String[] args) {

             String date = "2008/09/10";

            String[ ] dateAfterSplit= new String[3];

            dateAfterSplit=date.split("/");         //以“/”作為分隔符來分割date字元串,并把結果放入3個字元串中。

            for(int i=0;i<dateAfterSplit.length;i++)

                       System.out.print(dateAfterSplit[i]+" ");

      }

運作結果:2008 09 10          //結果為分割後的3個字元串

執行個體:

TestString1.java:

程式代碼

public class TestString1

{

    public static void main(String args[]) {

        String s1 = "Hello World" ;

        String s2 = "hello world" ;

        System.out.println(s1.charAt(1)) ;

        System.out.println(s2.length()) ;

        System.out.println(s1.indexOf("World")) ;

        System.out.println(s2.indexOf("World")) ;

        System.out.println(s1.equals(s2)) ;

        System.out.println(s1.equalsIgnoreCase(s2)) ;

        String s = "我是J2EE程式員" ;

        String sr = s.replace('我','你') ;

        System.out.println(sr) ;

    }

TestString2.java:

public class TestString2

        String s = "Welcome to Java World!" ;

        String s2 = "   magci   " ;

        System.out.println(s.startsWith("Welcome")) ;

        System.out.println(s.endsWith("World")) ;

        String sL = s.toLowerCase() ;

        String sU = s.toUpperCase() ;

        System.out.println(sL) ;

        System.out.println(sU) ;

        String subS = s.substring(11) ;

        System.out.println(subS) ;

        String s1NoSp = s2.trim() ;

        System.out.println(s1NoSp) ;