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";
????????//?注意要加\,要不出不來(lái),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對(duì)于字符串"192.168..33"的分割,返回的字符串?dāng)?shù)組只有3個(gè)元素,對(duì)于兩個(gè)分隔符之間的空字符串會(huì)忽略,這個(gè)要慎重使用。
但是String.split(String.split是用正則表達(dá)式匹配,所以不使用KMP字符串匹配算法)用的都是按順序遍歷的算法,時(shí)間復(fù)雜度O(m*n),較高,所以性能上,StringTokenizer好很多,對(duì)于頻繁使用字符串分割的應(yīng)用,例如etl數(shù)據(jù)處理,使用StringTokenizer性能可以提高很多。





