Java 的字符串API(部分)及字符串處理


最近在看Robert Sedgewick 和Kevin Wayne寫的算法(第四版) ,看到字符串部分,正好給出了Java字符串的API(部分,也是直接自己接觸的較為常用的)

覺得自己也應該好好總結一些,首先給一點簡單的,之后看到第五章部分,有關字符串的內容再補上。

 

表 Java 字符串API(部分)

Public class String

 

String()

創建一個空字符串

int

length()

字符串長度

int

charAt(int i)

第i個字符

int

indexOf(String p)

p第一次出現的位置(無則 -1)

int

indexOf(String p,int i)

p在i個字符后第一次出現的位置(無則-1)

String

concat(String t)

將t附在字符串末尾

String

substring(int i,int j)

該字符串的子字符串(從第i個到j-1個)

String[]

split(String delim)

使用delim分隔符切割字符串

int

compareTo(String t)

比較字符串

Boolean

equals(String t)

該字符串的值和t的值是否相同

int

hashCode

散列值

 

字符串操作舉例

1 String a = "now is ";
2 String b = "the time ";
3 String c = "to";

 

方法  返回值
a.length()  7
a.charAt(4)  i
a.concat(c)  "now is to"
a.indexOf("is")  4
a.substring(2,5)  "w i"
a.split(" ")[0]  "now"
a.split(" ")[1]  "is"
b.equals(c)  false

 

 

 

 

 

 

 

 

其中 “+” 運算符是可以代替concat()方法的。

還有一些高級的用法,比如 split()方法 的參數可以是 正則表達式 

典型的字符串處理代碼中split()的參數是“\\s+”  表示“一個或多個制表符、空格、換行符或回車”

 

典型字符串處理代碼如下:

任務一:判斷字符串是否是一條回文

1 public static boolean isPalindrome(String s){
2         int N = s.length();
3         for (int i = 0; i < N / 2; i++) {
4             if (s.charAt(i) != s.charAt(N-1-i))
5                 return false;
6         }
7         return true;
8     }

任務二:從一個命令行參數中提取文件名和擴展名

1 String s = args[0];
2 int dot = s.indexOf(".");
3 String base = s.substring(0,dot);
4 String extension = s.substring(dot+1,s.length());

任務三:打印出標准輸入中所有含有通過命令行指定的字符串的行

1 String query = args[0];
2 while (!StdIn.isEmpty()){
3   String s = StdIn.readLine();
4    if(s.contains(query)) StdOut.println(s);
5 }

任務四:以空白字符為分隔符從StdIn中創建一個字符串數組

1 String input = StdIn.readAll();
2 String[] words = input.split("\\s+");

任務五:檢查一個字符串數組中的元素是否已按照字母表順序排序

1 public boolean isSorted(String[] a){
2         for (int i = 1 ; i < a.length() ; i++) {
3             if (a[i-1].compareTo(a[i]) > 0)
4                 return false;
5         }
6         return true;
7     }

 

 

 

ps:東西到是沒多少,這個編輯起來好費勁啊.....

 

 

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM