forked from plusone/plusone-commons
使用双重检查,避免并发下同一个正则表达式编译多次。
parent
4676755967
commit
e0d793ba14
|
@ -29,12 +29,16 @@ public class RegexUtil {
|
||||||
|
|
||||||
public static Pattern getPattern(final String regex) {
|
public static Pattern getPattern(final String regex) {
|
||||||
Objects.requireNonNull(regex);
|
Objects.requireNonNull(regex);
|
||||||
if (PATTERN_CACHE.containsKey(regex)) {
|
if (!PATTERN_CACHE.containsKey(regex)) {
|
||||||
return PATTERN_CACHE.get(regex);
|
synchronized (RegexUtil.class) {
|
||||||
|
if (!PATTERN_CACHE.containsKey(regex)) {
|
||||||
|
Pattern pattern = Pattern.compile(regex);
|
||||||
|
PATTERN_CACHE.put(regex, pattern);
|
||||||
|
return pattern;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
Pattern pattern = Pattern.compile(regex);
|
return PATTERN_CACHE.get(regex);
|
||||||
PATTERN_CACHE.put(regex, pattern);
|
|
||||||
return pattern;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static boolean matches(@Nullable CharSequence input, String regex) {
|
public static boolean matches(@Nullable CharSequence input, String regex) {
|
||||||
|
|
Loading…
Reference in New Issue