欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Java中分割字符串的两种方法实例详解

程序员文章站 2024-03-31 20:17:52
前言 相信大家应该都知道在java编程中,有时候我们需要把一个字符串按照某个特定字符、字母等作为截点分割这个字符串,这样我们就可以使用这个字符串的一部分或者把所有截取的内...

前言

相信大家应该都知道在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个字符串
  int maxsplit = 3;
  sourcestrarray = sourcestr.split(",", maxsplit);
  for (int i = 0; i < sourcestrarray.length; i++) {
   system.out.println(sourcestrarray[i]);
  }
 }
}

输出结果:

1
2
3
4
5
1
2
3,4,5

split 的实现直接调用的 matcher 类的 split 的方法。在使用string.split方法分隔字符串时,分隔符如果用到一些特殊字符,可能会得不到我们预期的结果。

在正则表达式中有特殊的含义的字符,我们使用的时候必须进行转义,示例:

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分隔符总结

     1.字符"|","*","+"都得加上转义字符,前面加上"\\"。

     2.而如果是"\",那么就得写成"\\\\"。

     3.如果一个字符串中有多个分隔符,可以用"|"作为连字符。

比如:string str = "java string-split#test",可以用str.split(" |-|#")把每个字符串分开。这样就把字符串分成了3个子字符串。

二、java.util.tokenizer jdk 1.0 or later

stringtokenizer

stringtokenizer 类允许应用程序将字符串分解为标记。stringtokenizer 是出于兼容性的原因而被保留的遗留类(虽然在新代码中并不鼓励使用它)。建议所有寻求此功能的人使用 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"的分割,返回的字符串数组只有3个元素,对于两个分隔符之间的空字符串会忽略,这个要慎重使用。

但是string.splitstring.split是用正则表达式匹配,所以不使用kmp字符串匹配算法)用的都是按顺序遍历的算法,时间复杂度o(m*n),较高,所以性能上,stringtokenizer好很多,对于频繁使用字符串分割的应用,例如etl数据处理,使用stringtokenizer性能可以提高很多。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。