JavaSE 字符串和正则表达式

根据不懂的自己整理一下,跟着老师进度刷一遍课本,记录琐碎不懂知识

1.StringTokenizer类

      String[] mess= {"整数部分","小数部分"};
        Scanner reader=new Scanner(System.in);
        double x=reader.nextDouble();
        String s=String.valueOf(x);
        StringTokenizer fenxi=new StringTokenizer(s, ".");
        for(int i=0;fenxi.hasMoreTokens();i++) {
            String strr=fenxi.nextToken();
            System.out.println(mess[i]+":"+strr);
        }
        reader.close();

主要用于分割,调用hasMoreTokens方法可以判断是否到了最后,nextToken用于迭代

2.StringBuffer和StringBuilder区别

前者是线程安全的,因为加了synchronize锁

后者的线程不安全,但是效率比较高

3.正则

    String regex="(http://|www)[.]?\w+[.]{1}\w+[.]{1}\p{Alpha}+";
        String newStr=str.replaceAll(regex, "");//替代
        System.out.println(str);
        System.out.println(newStr);
String regex="\D+";
String str="apple9orange5pineapple";
String digitWord[]=str.split(regex);//返回与正则匹配的数组
System.out.println(Arrays.toString(digitWord));

4.模式匹配

Pattern p = Pattern.compile("a*b");
Matcher m = p.matcher("aaaaab");
boolean b = m.matches();
System.out.println(b);
         Pattern p = Pattern.compile("a");
         Matcher m = p.matcher("aaaaa");
         while(m.find()) {
             System.out.println(m.group());
         }        
原文地址:https://www.cnblogs.com/littlepage/p/9874100.html