gpt4 book ai didi

java - 为什么 useTransparentBounds() 不在 Matcher 区域之外进行搜索?

转载 作者:行者123 更新时间:2023-12-01 14:58:34 24 4
gpt4 key购买 nike

我尝试使用 useTransparentBounds() ,但它似乎没有按预期工作(如 ideone 中所示)。在下面的代码片段中,我期望 m.find() 找到匹配项,因为启用了透明边界,从而允许匹配器在其区域边界之外进行搜索。为什么这不起作用?

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

class Foo {
public static void main(String[] args) {
// match everything preceded by X
Matcher m = Pattern.compile(".*(?<=X)").matcher("Foo BarX Baz");

// limit matcher to first chars outside of normal lookahead scope
m.region(0, 4);

// matcher should still find a match because of transparent bounds
m.useTransparentBounds(true);

// this fails to find a match! why?
System.out.println("found=" + m.find());
System.out.println("result=" + m.group());
}
}

(我在 Mac OSX Mountain Lion 上使用 J2SE 6 (1.6.0_37-b06-434-11M3909))

最佳答案

首先,(?<=X)是后视,而不是前视;我想你的意思是 .*(?=X) 。现在让我们开始检查当不限制匹配区域时会发生什么。

最初,.*消耗整个字符串( "Foo BarX Baz" ),然后将控制权交给 (?=X) (前瞻),断言下一个字符是 X 。这失败了(显然),因此匹配器返回最后一个字符并尝试仅使用 "Foo BarX Ba" ,但他的前瞻再次失败。如此继续,直到达到消耗"Foo Bar"的程度。 。下一个字符现在是 X ,因此前瞻成功。

如果将区域限制为 (0,7)您可能希望它继续工作。 知道下一个字符是 X ,无论如何,您只是想查看 X ,不消耗它。但不,匹配器甚至看不到它。它的行为与您将其应用到 "Foo Bar" 时完全相同。首先。它不会打扰查看 r 之后的字符。 ,因为它认为此后没有任何字符。

无论如何,这是默认行为。什么useTransparentBounds(true)的作用是使匹配器能够超越区域边界,以匹配零宽度断言(环视、字边界等)。您仍然无法使用当前区域之外的任何内容;这不是它的目的。

您的正则表达式不起作用的原因是它只查看字符串的前四个字符。为了使前瞻成功,必须有 X位于索引 #4(例如 "Foo X" )。

关于java - 为什么 useTransparentBounds() 不在 Matcher 区域之外进行搜索?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14008897/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com