我正在开发一个Android项目,该项目使用我正在创建的单独JAR文件中的类和方法,问题在于一个名为XpathUtil
的特定util类,每个都抛出一个VerifyError
我试着调用一种静态方法。
以下是我的XpathUtil类的外观:
public class XpathUtil {
private static XPath xpath = XPathFactory.newInstance().newXPath();
private static String TAG = "XpathUtil";
public static Document createXpathDocument(String xml) {
try {
Log.d(TAG , "about to create document builder factory");
DocumentBuilderFactory docFactory = DocumentBuilderFactory
.newInstance();
Log.d(TAG , "about to create document builder ");
DocumentBuilder builder = docFactory.newDocumentBuilder();
Log.d(TAG , "about to create document with parsing the xml string which is: ");
Log.d(TAG ,xml );
Document document = builder.parse(new InputSource(
new StringReader(xml)));
Log.d(TAG , "If i see this message then everythings fine ");
return document;
} catch (Exception e) {
e.printStackTrace();
Log.d(TAG , "EXCEPTION OCCURED HERE " + e.toString());
return null;
}
}
public static NodeList getNodeList(Document doc, String expr) {
try {
Log.d(TAG , "inside getNodeList");
XPathExpression pathExpr = xpath.compile(expr);
return (NodeList) pathExpr.evaluate(doc, XPathConstants.NODESET);
} catch (XPathExpressionException e) {
e.printStackTrace();
}
return null;
}
// extracts the String value for the given expression
public static String getNodeValue(Node n, String expr) {
try {
Log.d(TAG , "inside getNodeValue");
XPathExpression pathExpr = xpath.compile(expr);
return (String) pathExpr.evaluate(n, XPathConstants.STRING);
} catch (XPathExpressionException e) {
e.printStackTrace();
}
return null;
}
}
这是我正在使用的主项目发生异常的确切行:
mDocument = XpathUtil.createXpathDocument(xml);
正如你所看到的,我所做的只是简单的调用createXpathDocument
,它位于一个单独的jar文件中,该文件已成功导入并通过eclipse包含在我的构建路径中(我对其他类进行的任何其他调用)从这个jar工作正常)。所以我不太清楚问题是什么。
我尝试干净并构建主项目和我正在使用的其他项目,然后将其导出到实际的jar文件以供第三方应用程序使用,但由于某些奇怪的原因,此XpathUtil无法正常工作。 / p>
编辑:这是例外:
Uncaught handler: thread AsyncTask #1 exiting due to uncaught exception
java.lang.RuntimeException: An error occured while executing doInBackground()
at
android.os.AsyncTask$3.done(AsyncTask.java:200)
at
java.util.concurrent.FutureTask$Sync.innerSetException(FutureTask.java:273) at
java.util.concurrent.FutureTask.setException(FutureTask.java:124)
at
java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:307)
at
java.util.concurrent.FutureTask.run(FutureTask.java:137) at
java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1068)
at
java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:561)
at
java.lang.Thread.run(Thread.java:1096)
Caused by: java.lang.VerifyError:
com.kc.unity.agent.util.xml.XpathUtil at com.kc.unity.agent.util.xml.ContactDescHelper.<init>
(ContactDescHelper.java:67)
at
com.kc.unity.agent.federation.contacts.ContactPlatformWrapper.constructContactDetails
(ContactPlatformWrapper.java:218)
at
com.kc.unity.agent.federation.contacts.ContactPlatformWrapper.getContactDetails
(ContactPlatformWrapper.java:101) at
com.kc.unified.contacts.ContactDetails.setContactFields(ContactDetails.java:154) at com.kc.unified.contacts.ContactDetails.access$6
(ContactDetails.java:150) at
com.kc.unified.contacts.ContactDetails$LoadScreen.doInBackground(ContactDetails.java:79)
at
com.kc.unified.contacts.ContactDetails$LoadScreen.doInBackground(ContactDetails.java:1)
at android.os.AsyncTask$2.call(AsyncTask.java:185) at
java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305)... 4 more
答案 0 :(得分:2)
导致VerifyErrors的典型场景:您有两个不同版本的库,针对版本1进行编译并使用版本2运行。在这种情况下,特别是如果方法签名已更改,JVM可能会抱怨{{1 }}
因此,对于您的情况:仔细检查您是否使用完全相同的VerifyError
文件进行构建和执行。也许JVM在类路径上有这个类的旧版本(可能它有多个版本并选择了错误的版本)。
答案 1 :(得分:2)
当我将ADT工具更新到版本18.0.0.v201203301601-306762时 当我运行应用程序时,我也得到了异常.... 最后我找到了解决adt更新问题的解决方案。 当您构建Android应用程序项目时,您需要转到项目属性 - &gt;订购和导出,并选中第三方jar复选框,并清理并重建项目。 问题将得到解决...... for example