java正则表达式性能_java – 比较不同正则表达式的性能,需要澄清

考虑3个正则表达式,旨在从字符串中删除非拉丁字符.

String x = "some†¥¥¶¶ˆ˚˚word";

long now = System.nanoTime();

System.out.println(x.replaceAll("[^a-zA-Z]", "")); // 5ms

System.out.println(System.nanoTime() - now);

now = System.nanoTime();

System.out.println(x.replaceAll("[^a-zA-Z]+", "")); // 2ms

System.out.println(System.nanoTime() - now);

now = System.nanoTime();

System.out.println(x.replaceAll("[^a-zA-Z]*", "")); // <1ms

System.out.println(System.nanoTime() - now);

所有3个产生相同的结果,性能指标差别很大.

这是为什么?

最佳答案 第一个较慢,因为正则表达式单独匹配每个非拉丁字符,因此replaceAll分别对每个字符进行操作.

其他模式匹配非拉丁字符的整个序列,因此replaceAll可以一次性替换整个序列.但是,我无法解释这两者之间的性能差异.可能与处理*和正则表达式引擎中的差异有关.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值