首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >java.lang.NoClassDefFoundError: com.factual.driver.Factual

java.lang.NoClassDefFoundError: com.factual.driver.Factual
EN

Stack Overflow用户
提问于 2013-12-01 00:41:11
回答 1查看 208关注 0票数 0

在我的Android应用程序中使用实际API时,我遇到了一个问题。我想我已经添加了所有正确的jar文件。请看这里:

这是我的日志:

代码语言:javascript
复制
11-30 19:27:03.033: E/AndroidRuntime(4538): FATAL EXCEPTION: main
11-30 19:27:03.033: E/AndroidRuntime(4538): Process: com.example.foodsaver2, PID: 4538
11-30 19:27:03.033: E/AndroidRuntime(4538): java.lang.NoClassDefFoundError: com.factual.driver.Factual
11-30 19:27:03.033: E/AndroidRuntime(4538):     at com.example.foodsaver2.DatabaseFiller.onCreate(DatabaseFiller.java:70)
11-30 19:27:03.033: E/AndroidRuntime(4538):     at android.app.Activity.performCreate(Activity.java:5243) 
11-30 19:27:03.033: E/AndroidRuntime(4538):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
11-30 19:27:03.033: E/AndroidRuntime(4538):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2140)
11-30 19:27:03.033: E/AndroidRuntime(4538):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2226)
11-30 19:27:03.033: E/AndroidRuntime(4538):     at  android.app.ActivityThread.access$700(ActivityThread.java:135)
11-30 19:27:03.033: E/AndroidRuntime(4538):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1397)
11-30 19:27:03.033: E/AndroidRuntime(4538):     at android.os.Handler.dispatchMessage(Handler.java:102)
11-30 19:27:03.033: E/AndroidRuntime(4538):     at android.os.Looper.loop(Looper.java:137)
11-30 19:27:03.033: E/AndroidRuntime(4538):     at android.app.ActivityThread.main(ActivityThread.java:4998)
11-30 19:27:03.033: E/AndroidRuntime(4538):     at java.lang.reflect.Method.invokeNative(Native Method)
11-30 19:27:03.033: E/AndroidRuntime(4538):     at java.lang.reflect.Method.invoke(Method.java:515)
11-30 19:27:03.033: E/AndroidRuntime(4538):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:777)
11-30 19:27:03.033: E/AndroidRuntime(4538):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:593)
11-30 19:27:03.033: E/AndroidRuntime(4538):     at dalvik.system.NativeStart.main(Native Method)

这里怎么了?我做错了什么?顺便说一下,这里是我的AndroidManifest的一部分:

代码语言:javascript
复制
application android:label="@string/app_name">
            <uses-library android:name="com.factual.driver.Factual" />

<activity android:name=".DatabaseFiller" android:label="@string/app_name">

在DatabaseFiller的第70行:

代码语言:javascript
复制
/*this is line 69, next line is 70*/ try {
        Factual factual = new Factual("perosnal", "personal");
        factual.fetch("products-cpg-nutrition", 
                new Query().search("028367831679"));
        // row filter
        Query q = new Query();
        factual.fetch("products-cpg-nutrition", 
                q.or(q.field("upc").isEqual("028367831679"),
                        q.field("ean13").isEqual("028367831679")));
        Toast.makeText(getApplicationContext(), (CharSequence) q, Toast.LENGTH_SHORT).show();
    }
    catch (Exception e) {

    }

这里怎么了?我已经把头撞在墙上好一阵子了。我已经查过了,但我不能把针头钉在解决方案上。任何帮助都是非常感谢的。

编辑!另一条消息也出现在Logcat中,我忘了添加:

代码语言:javascript
复制
11-30 20:44:09.993: E/dalvikvm(11654): Could not find class 'com.factual.driver.Factual', referenced from method com.example.foodsaver2.DatabaseFiller.onCreate

但是我把它放在我的AndroidManifest文件中。任何帮助都将不胜感激。

EN

回答 1

Stack Overflow用户

发布于 2013-12-01 00:57:46

请不要将此视为回答,而应视为评论。我还没有特权发表评论。请不要否定它。

据我所知:

您提到的行不能是错误的位置。因为如果它在try块中遇到任何问题,您的代码(try and catch)就是swallowing the exception stopping it from throwing an exception

这可能是错误的地方,您正在寻找错误。

此外,如果它在实例创建中无法识别'Factual',它将给出编译错误,而不是运行时异常。

代码语言:javascript
复制
I would say figure out the exact location of the issue.
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/20307407

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档