国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > Java > 正文

Java 分割字符串詳解及實(shí)例代碼

2019-11-26 13:23:25
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

 Java 分割字符串

java.lang.String 的 split() 方法, JDK 1.4 or later

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é)果:

12345123,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("http://.");    for (int i = 0; i < names.length; i++) {      System.out.println(names[i]);    }  }}

split分隔符總結(jié)

1.字符"|","*","+"都得加上轉(zhuǎn)義字符,前面加上"http://"。

2.而如果是"/",那么就得寫(xiě)成"////"。

3.如果一個(gè)字符串中有多個(gè)分隔符,可以用"|"作為連字符。

比如:String str = "Java string-split#test",可以用Str.split(" |-|#")把每個(gè)字符串分開(kāi)。這樣就把字符串分成了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性能可以提高很多。

感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 崇明县| 灵台县| 南康市| 嵩明县| 临澧县| 辽宁省| 扶沟县| 房产| 邵东县| 吉隆县| 尉犁县| 玉门市| 凤冈县| 北海市| 内黄县| 潮安县| 沂源县| 涿州市| 合水县| 湖州市| 阿克陶县| 昌宁县| 贺兰县| 克东县| 万荣县| 富裕县| 正蓝旗| 南丰县| 南澳县| 儋州市| 若尔盖县| 新乡市| 长岭县| 宣城市| 古田县| 平谷区| 扶沟县| 新宁县| 扶沟县| 巢湖市| 诏安县|