我在Java函数中运行正则表达式来解析文档,如果找到了由正则表达式指定的字符串,则返回true,否则,则返回false。但是问题在于,当文档不包含正则表达式指定的字符串时,返回false花费的时间很长,如果要花费6秒钟以上的时间来执行,我想终止该函数。
我如何在该功能上设置6秒的时限,以便在超过6秒时强行终止该功能。
我从类1调用类2的方法“方法1”。“方法1”调用相同类的“方法2”,即“类2”。方法2在文档上运行正则表达式代码。如果找到由正则表达式指定的字符串,则将结果返回到方法1,然后方法1将结果返回到“类1”中的方法,该方法称为类2的“方法1”。现在的问题是类2的method1和method2的执行时间应不超过6秒。
因此,我在class2所在的同一文件中创建了一个新的RegexpThread类。然后,将class2的method2移到RegexpThread类中。然后,无论何时调用方法1,它都会实例化RegexpThread类,如下所示:
RegexpThread rt = new RegexpThread() {
public void run() {
method 2(m, urlCopy, document);
}
};
rt.start();
try {
rt.join(6 * 1000);
} catch (InterruptedException e) {
return "y";
}
if(rt.getResultXml().equals("")) {
return "g";
}
resultXml.append(rt.getResultXml());
return resultXml.toString();
显示的代码在class2的方法1中。RegexpThread类中的方法2对文档执行一些正则表达式搜索。RegexpThread类中有一个名为“
resultXml”的私有字段。如果方法2找到了正则表达式指定的字符串,则将结果分配给私有字段“ resultXml”。如果不是,则“
resultXml”包含其默认值,即空字符串。
因此,在上面的“ if块”中,它正在针对空字符串检查“
resultXml”字段。如果它是一个空字符串,则表示该正则表达式未在文档中找到其字符串。但是,如果它不是一个空字符串,则表示正则表达式已在文档中找到该字符串,并将结果分配给了“
resultXml”字段。
所以,看看这个,告诉我该怎么做…
您所做的对我来说看起来不错,这是我将对其进行修改的方式:
final AtomicReference<String> resultXml = new AtomicReference<String>();
RegexpThread rt = new RegexpThread() {
public void run() {
method2(m, urlCopy, document, resultXml);
}
};
rt.start();
try {
rt.join(6 * 1000);
} catch (InterruptedException e) {
return "y";
}
if(resultXml.get() == null) {
rt.interupt();
return "g";
}
resultXml.append(resultXml.get());
return resultXml.toString();
问题内容: 我有一个返回String的方法,是否有可能在一段时间后超出该阈值以返回该特定字符串? 问题答案: 该番石榴库有一个非常好的,可以让你做到这一点,就会向由接口定义的任何方法。它可以为具有“内置”超时的对象生成代理。
我在我的程序中添加了一个记录器,在网上冲浪我在代码中添加了一个非常简单的记录器,具有基本的两行定义: 经过几个小时的开发,我想知道如何格式化记录文本的样式,于是我来到了这门课: 阅读Javadoc我可以找到: 可以通过在java中指定格式字符串来定制格式。util。登录中。简单格式化程序。格式属性。 还有几个例子: 我试了每一个,但“格式”字段是“不可见”(我想是私有的),所以我不能直接编辑它。没
我有一个正则表达式,它适用于 (字母数字-不分大小写) (仅限字母-与大小写无关) (只允许使用特殊字符和) null 我们是否可以修改上面的正则表达式来限制上面的两个测试用例?
问题内容: 我需要这样的匹配器: 问题是它不是简单的ASCII。我知道在这种特殊情况下,我可以将[\ u00FC \ u00DC]用于ü,但是我需要更加通用(从其他匹配器组构建正则表达式)。所以根据javadocs: 默认情况下,不区分大小写的匹配假定只匹配US- ASCII字符集中的字符。可以通过将UNICODE_CASE标志与该标志一起指定来启用Unicode感知的不区分大小写的匹配。 谁能告
有几个问题,但没有回答我的问题。我希望使用pattern和matcher在字符串中找到一个模式,然后从那里创建一个匹配列表,其中包括不匹配的其余部分。 我目前的结果: 假的 我的预期结果应该在列表中: ["125t","160f"]//我知道如何在python中做到这一点,但不知道如何在java中做到这一点。所以有人能帮我吗?
我有以下正则表达式和示例输入: http://regex101.com/r/xK9dE3 正如你所看到的,它与第一个“哟”相匹配。我只希望图案和“砍我”在同一行(第二个“哟”)图案上匹配。 如何确保正则表达式匹配只在同一行上? 输出: 预期输出(这是我真正想要的):