У меня проблема с крошечным тестовым скриптом:
import java.util.regex.Pattern;
import java.util.regex.Matcher;
cfgText = "PATTERN1 = 9\nPATTERN2 = 136.225.73.44\nPATTERN3 = 136.225.236.12"
cfgLine = cfgText.split('\n');
def p = /.*PATTERN2.*/;
def PATTERN2_found = false;
for (i=0; PATTERN2_found==false && i < cfgLine.length; i++)
{
println("cfgLine" +i+ ": " + cfgLine[i]);
def m = cfgLine[i] =~ p;
println("m: " + m)
println("m.asBoolean(): " + m.asBoolean());
println("m: " + m)
println("m.asBoolean(): " + m.asBoolean());
if(m.asBoolean()){
println("Heeeyyyy");
}
println("--------------------------------");
}
Это его вывод:
cfgLine0: PATTERN1 = 9
m: java.util.regex.Matcher[pattern=.*PATTERN2.* region=0,12 lastmatch=]
m.asBoolean(): false
m: java.util.regex.Matcher[pattern=.*PATTERN2.* region=0,12 lastmatch=]
m.asBoolean(): false
--------------------------------
cfgLine1: PATTERN2 = 136.225.73.44
m: java.util.regex.Matcher[pattern=.*PATTERN2.* region=0,24 lastmatch=]
m.asBoolean(): true
m: java.util.regex.Matcher[pattern=.*PATTERN2.* region=0,24 lastmatch=PATTERN2 = 136.225.73.44]
m.asBoolean(): false
--------------------------------
cfgLine2: PATTERN3 = 136.225.236.12
m: java.util.regex.Matcher[pattern=.*PATTERN2.* region=0,25 lastmatch=]
m.asBoolean(): false
m: java.util.regex.Matcher[pattern=.*PATTERN2.* region=0,25 lastmatch=]
m.asBoolean(): false
--------------------------------
WARNING: An illegal reflective access operation has occurred
WARNING: Illegal reflective access by org.codehaus.groovy.reflection.CachedConstructor$1 (file:/usr/share/groovy/lib/groovy-2.4.15.jar) to constructor java.util.regex.Matcher()
WARNING: Please consider reporting this to the maintainers of org.codehaus.groovy.reflection.CachedConstructor$1
WARNING: Use --illegal-access=warn to enable warnings of further illegal reflective access operations
WARNING: All illegal access operations will be denied in a future release
Как вы можете видеть совпадения регулярного выражения во втором цикле, ноповедение странно для меня.Я действительно не знаю, почему, если я использую ДВА asBoolean
против одного и того же объекта Matcher, результат будет другим.Есть ли у него внутренний итератор или что-то в этом роде?
PS: я решил это с помощью оператора ==~
, но я хотел бы знать, почему asBoolean работает так.