0

我正在尝试编写一个程序来解析 Java 垃圾收集日志。我刚刚创建了一个与次要集合匹配的语法。一旦我确定了一个模式,我想把它解析成单独的标记。我的问题是,有没有什么优雅的方法可以用我之前定义的语法来做到这一点?

public class RegexTestHarness {
  private final static String REGEX_SMALL_COLLECTION = "\\d+\\.\\d+: \\[GC \\d+.\\d+: \\[ParNew: \\d+K\\-\\>0K\\(\\d+K\\), \\d+.\\d+ secs\\] \\d+K\\-\\>\\d+K\\(\\d+K\\), \\d+.\\d+ secs\\]";

  public static void main(String[] args){
    Pattern pattern = Pattern.compile(REGEX_SMALL_COLLECTION);           
    Matcher matcher = pattern.matcher("54.770: [GC 54.770: [ParNew: 5232768K->0K(5237824K), 1.1304192 secs] 5238622K->380448K(10480704K), 1.1306410 secs]");
    while (matcher.find()) {            
      System.out.println(matcher.group(0));
      System.out.println(matcher.start());
      System.out.println(matcher.end()); 
    }
  }
}
4

1 回答 1

1

您需要将组添加到您的正则表达式。

private final static String REGEX_SMALL_COLLECTION = "(\\d+\\.\\d+): \\[GC (\\d+.\\d+): \\[ParNew: \\d+K\\-\\>0K\\(\\d+K\\), \\d+.\\d+ secs\\] \\d+K\\-\\>\\d+K\\(\\d+K\\), \\d+.\\d+ secs\\]";

然后访问这些组的值。在上面的示例中,我在您想要的前两项周围添加了括号——这告诉正则表达式引擎捕获匹配的子字符串。您将需要添加更多。正如您目前所做的那样,您使用Matcher.group()来获取每个组。请注意,第 0 组始终是整场比赛。其余的从1上开始编号,按照它们的开头括号的顺序(

于 2012-07-26T13:33:12.997 回答