java正则化,返回同一字符串多处匹配结果。

1、需求:
正则化匹配时,正则表达式pattern,需要匹配字符传string中的多处,并将没一处的位置信息返回!
2、代码:

import java.util.ArrayList;
import java.util.HashMap;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class test {
    public static void main(String[] args) {
        ArrayList<HashMap<String,Object>> list=new ArrayList<HashMap<String, Object>>();
        //“zidian”定义在此处,赋值要在循环内。
        HashMap<String,Object> zidian = null;
        String ss="ooaaoo";
        Pattern pt=Pattern.compile("(o+)");
        Matcher mt=pt.matcher(ss);
//        mt.lookingAt();
        // mt.matches();
        while(mt.find()){
            System.out.println(mt.start());
            //赋值位置,每次循环要重新给字典赋内存空间,否则最后结果会覆盖前面结果。
            zidian=new HashMap<String, Object>();
//            System.out.println(mt.end());
//            System.out.println(mt.group());
            zidian.put("start",mt.start());
            zidian.put("end",mt.end());
            zidian.put("content",mt.group());
//            ArrayList<Integer> span = new ArrayList<Integer>();
//            span.add(mt.start());
//            span.add(mt.end());
//            zidian.put("span", span);
//            System.out.println(zidian);
            list.add(zidian);
            System.out.println(list);

        }

    }
}

错误代码: HashMap<String,Object> zidian = new HashMap<String, Object>();
这种方式,字典在存入list时,一直固定存入list的制定空间,当zidian值变化后,会覆盖原来的值。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值