我在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找到了正则表达式指定的字符串,则将结果分配给私有(private)字段“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();