public?String[]?split(String?regex,int limit)
示例代碼
public?class?StringSplit?{ ????public?static?void?main(String[]?args)?{ ????????String?sourceStr?=?"1,2,3,4,5"; ????????String[]?sourceStrArray?=?sourceStr.split(","); ????????for?(int?i?=?0;?i?<?sourceStrArray.length;?i++)?{ ????????????System.out.println(sourceStrArray[i]); ????????} ????????//?最多分割出3個(gè)字符串 ????????int?maxSplit?=?3; ????????sourceStrArray?=?sourceStr.split(",",?maxSplit); ????????for?(int?i?=?0;?i?<?sourceStrArray.length;?i++)?{ ????????????System.out.println(sourceStrArray[i]); ????????} ????} }
輸出結(jié)果:
1 2 3 4 5 1 2 3,4,5
split 的實(shí)現(xiàn)直接調(diào)用的 matcher 類的 split 的方法。在使用String.split方法分隔字符串時(shí),分隔符如果用到一些特殊字符,可能會(huì)得不到我們預(yù)期的結(jié)果。在正則表達(dá)式中有特殊的含義的字符,我們使用的時(shí)候必須進(jìn)行轉(zhuǎn)義,示例:
public?class?StringSplit?{ ????public?static?void?main(String[]?args)?{ ????????String?value?=?"192.168.128.33"; ????????//?注意要加\,要不出不來,yeah ????????String[]?names?=?value.split("\."); ????????for?(int?i?=?0;?i?<?names.length;?i++)?{ ????????????System.out.println(names[i]); ????????} ????} }
split分隔符總結(jié)
1.字符"|","*","+"都得加上轉(zhuǎn)義字符,前面加上"\"。
2.而如果是"",那么就得寫成"\\"。
3.如果一個(gè)字符串中有多個(gè)分隔符,可以用"|"作為連字符。
比如:String str = "Java string-split#test",可以用Str.split(" |-|#")把每個(gè)字符串分開。這樣就把字符串分成了3個(gè)子字符串。
?
?java.util.Tokenizer JDK 1.0 or later
StringTokenizer
StringTokenizer?類允許應(yīng)用程序?qū)⒆址纸鉃闃?biāo)記。StringTokenizer 是出于兼容性的原因而被保留的遺留類(雖然在新代碼中并不鼓勵(lì)使用它)。建議所有尋求此功能的人使用 String 的 split 方法或 java.util.regex 包。
代碼示例
public?class?StringSplit?{ ????public?static?void?main(String[]?args)?{ ????????String?ip?=?"192.168.128.33"; ????????StringTokenizer?token=new?StringTokenizer(ip,".");?? ????????while(token.hasMoreElements()){?? ?????????System.out.print(token.nextToken()+"??");?? ????????}? ????} }
但是StringTokenizer對于字符串"192.168..33"的分割,返回的字符串?dāng)?shù)組只有3個(gè)元素,對于兩個(gè)分隔符之間的空字符串會(huì)忽略,這個(gè)要慎重使用。
但是String.split(String.split是用正則表達(dá)式匹配,所以不使用KMP字符串匹配算法)用的都是按順序遍歷的算法,時(shí)間復(fù)雜度O(m*n),較高,所以性能上,StringTokenizer好很多,對于頻繁使用字符串分割的應(yīng)用,例如etl數(shù)據(jù)處理,使用StringTokenizer性能可以提高很多。