尝试运行引用库的lite版本时ClassNotFoundException

时间:2013-03-13 10:45:21

标签: java android classnotfoundexception android-library

我让我的主要项目工作并完成了。我开始研究如何制作精简版/专业版,现在一切都搞砸了。我将主项目设为Android Library,其名称为BibleTrivia,现在还有另外两个引用它的项目,名为BibleTriviaLiteBibleTriviaPro。我以为我已经完成了所有工作但是当我尝试运行lite版本时,我在尝试查找第一个活动ClassNotFoundException时得到SplashScreenSplashScreen对于lite和pro版本是相同的,所以我在库项目中有它。

我的问题是如何使这个结构正确,所以我可以运行我的精简版和专业版,没有这个例外。

我在下面显示了我的LogCat输出和我的文件结构。如果您还需要更多信息,请与我们联系。

logcat的

03-09 02:10:52.745: E/AndroidRuntime(4706): FATAL EXCEPTION: main
03-09 02:10:52.745: E/AndroidRuntime(4706): java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{matt.lyons.bibletrivia.lite/matt.lyons.bibletrivia.lite.SplashScreen}: java.lang.ClassNotFoundException: Didn't find class "matt.lyons.bibletrivia.lite.SplashScreen" on path: /data/app/matt.lyons.bibletrivia.lite-1.apk
03-09 02:10:52.745: E/AndroidRuntime(4706):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2106)
03-09 02:10:52.745: E/AndroidRuntime(4706):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
03-09 02:10:52.745: E/AndroidRuntime(4706):     at android.app.ActivityThread.access$600(ActivityThread.java:141)
03-09 02:10:52.745: E/AndroidRuntime(4706):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
03-09 02:10:52.745: E/AndroidRuntime(4706):     at android.os.Handler.dispatchMessage(Handler.java:99)
03-09 02:10:52.745: E/AndroidRuntime(4706):     at android.os.Looper.loop(Looper.java:137)
03-09 02:10:52.745: E/AndroidRuntime(4706):     at android.app.ActivityThread.main(ActivityThread.java:5039)
03-09 02:10:52.745: E/AndroidRuntime(4706):     at java.lang.reflect.Method.invokeNative(Native Method)
03-09 02:10:52.745: E/AndroidRuntime(4706):     at java.lang.reflect.Method.invoke(Method.java:511)
03-09 02:10:52.745: E/AndroidRuntime(4706):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
03-09 02:10:52.745: E/AndroidRuntime(4706):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
03-09 02:10:52.745: E/AndroidRuntime(4706):     at dalvik.system.NativeStart.main(Native Method)
03-09 02:10:52.745: E/AndroidRuntime(4706): Caused by: java.lang.ClassNotFoundException: Didn't find class "matt.lyons.bibletrivia.lite.SplashScreen" on path: /data/app/matt.lyons.bibletrivia.lite-1.apk
03-09 02:10:52.745: E/AndroidRuntime(4706):     at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:65)
03-09 02:10:52.745: E/AndroidRuntime(4706):     at java.lang.ClassLoader.loadClass(ClassLoader.java:501)
03-09 02:10:52.745: E/AndroidRuntime(4706):     at java.lang.ClassLoader.loadClass(ClassLoader.java:461)
03-09 02:10:52.745: E/AndroidRuntime(4706):     at android.app.Instrumentation.newActivity(Instrumentation.java:1054)
03-09 02:10:52.745: E/AndroidRuntime(4706):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2097)
03-09 02:10:52.745: E/AndroidRuntime(4706):     ... 11 more

enter image description here

修改

这是我的精简AndroidManifest的开始。 LogCat为SplashScreen活动说ClassNotFoundException,因此它会读取下面的清单,但无法找到SplashScreen启动器活动。

<manifest 
    xmlns:android="http://schemas.android.com/apk/res/android"
    package="matt.lyons.bibletrivia.lite"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="15" />

    <application
        android:icon="@drawable/icon_lite"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name=".SplashScreen"
            android:screenOrientation="portrait" >
            <intent-filter>
                <action
                    android:name="android.intent.action.MAIN" />
                <category
                    android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity 
            android:name="com.google.ads.AdActivity"
            android:configChanges="keyboard|keyboardHidden|orientation|screenLayout|uiMode|screenSize|smallestScreenSize" />
        <activity
            android:label="@string/app_name"
            android:name=".About"
            android:screenOrientation="portrait" />
    ...
    ...more activities...
    ...
</manifest>

1 个答案:

答案 0 :(得分:1)

正如原始邮政建议的那样,我发布我的评论有答案,因为它解决了问题。

在您发布的图片中,我可以看到SplashScreen Activity类位于包 matt.lyons.bibletrivia 中。有了这些信息,再加上您的清单文件,我可以得出以下结论:

  1. 您将 matt.lyons.bibletrivia.lite 的默认包定义为清单文件中的属性

  2. 您将SplashScreen活动定义为默认包中,因为您将活动定义为 android:name =“。SplashScreen”。这导致寻找不存在的matt.lyons.bibletrivite.lite.SplashScreen类。

  3. 要解决您的问题,您只需使用完整的类名定义您的SplashScreen活动,即:

    android:name=".SplashScreen" 
    

    应替换为

    android:name="matt.lyons.bibletrivite.SplashScreen"
    

    一切都应该正常。