国产探花免费观看_亚洲丰满少妇自慰呻吟_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ā)表
主站蜘蛛池模板: 松江区| 巴里| 新源县| 兴宁市| 五莲县| 淮阳县| 西乌珠穆沁旗| 翼城县| 密云县| 文水县| 黄骅市| 丁青县| 宁蒗| 绥芬河市| 睢宁县| 德州市| 中阳县| 孙吴县| 邵阳县| 兴业县| 九江县| 富锦市| 屯留县| 庄浪县| 平阴县| 林西县| 浮梁县| 搜索| 博兴县| 南投市| 徐水县| 广德县| 濮阳市| 宕昌县| 怀来县| 天水市| 蓝山县| 台东县| 兴国县| 定结县| 永吉县|