无法实例化活动...由ClassNotFoundException引起

时间:2011-06-13 01:15:05

标签: java android android-library

将完美工作的应用程序转换为库(包括其Activity类!)后,我试图通过简单地超类化库的活动来创建一个使用整个库的应用程序:

package com.example.baseapp.paid;

import android.os.Bundle;
import com.example.baseapp.LibActivity;


public class PaidActivity extends LibActivity {
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
    }
}

Eclipse构建这个新的“重新架构”应用程序没有任何错误,但是当我尝试运行它时,我得到一个例外:

FATAL EXCEPTION: main
java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.example.baseapp.paid/com.example.baseapp.paid.PaidActivity}: java.lang.ClassNotFoundException: com.example.baseapp.paid.PaidActivity in loader dalvik.system.PathClassLoader[/data/app/com.example.baseapp.paid-1.apk]
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2585)
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
    at android.app.ActivityThread.access$2300(ActivityThread.java:125)
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
    at android.os.Handler.dispatchMessage(Handler.java:99)
    at android.os.Looper.loop(Looper.java:123)
    at android.app.ActivityThread.main(ActivityThread.java:4627)
    at java.lang.reflect.Method.invokeNative(Native Method)
    at java.lang.reflect.Method.invoke(Method.java:521)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
    at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.ClassNotFoundException: com.example.baseapp.paid.PaidActivity in loader dalvik.system.PathClassLoader[/data/app/com.example.baseapp.paid-1.apk]
    at dalvik.system.PathClassLoader.findClass(PathClassLoader.java:243)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:573)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:532)
    at android.app.Instrumentation.newActivity(Instrumentation.java:1021)
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2577)
    ... 11 more

我不知道为什么会发生这种情况,因为当类完全是构建的派生类(没有错误!)并且现在正在尝试运行时,“未找到类”的错误。

如何解决此问题?

我错过了什么?

编辑(通过@CaspNZ回答问题):

这是图书馆项目的AndroidManifest.xml:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
      package="com.example.baseapp"
      android:versionCode="5"
      android:versionName="1.1.2"> 
    <uses-sdk android:minSdkVersion="8" />

    <uses-permission android:name="android.permission.INTERNET"/>   
</manifest>

这是应用程序的AndroidManifest.xml,使用库项目:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
      package="com.example.baseapp.paid"
      android:versionCode="5"
      android:versionName="1.1.2"> 
    <uses-sdk android:minSdkVersion="8" />
    <uses-library android:name="AppLibrary" />

    <uses-permission android:name="android.permission.INTERNET"/>   

    <application android:icon="@drawable/icon">
        <activity android:name=".PaidActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity android:name="com.example.baseapp.LibActivity" android:label="com.example.baseapp.LibActivity:string/rx_label">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity android:name="EditPreferences" 
                android:label="com.example.baseapp.LibActivity:string/app_name">
        </activity>
    </application>
</manifest>

我很感激任何尝试解决这个问题的提示,因为这是我第一次尝试使用图书馆项目,而且我并不熟悉这项工作所涉及的“技巧”。

4 个答案:

答案 0 :(得分:10)

对于更新到ADT 22的任何人,请确保您已在Java Build Path&gt;中检查过Android私有库。订单和导出选项卡。有关详细信息,请阅读this。这适合我。也许没有什么力量可以将用户转移到Android Studio而不是Eclipse :))

答案 1 :(得分:1)

如果列出库清单中的活动而不是应用程序清单中的活动,则会发生这种情况。没有必要&lt; activity&gt;库清单中的标签。 (例如,参见this thread。)

答案 2 :(得分:1)

我终于解决了这个问题。事实证明,我在两个项目的属性中有两个关键设置未正确设置:

  1. 在图书馆项目中,“是图书馆” 由于某种原因检查。 我发誓,我检查过它,但是 知道Android有多么异想天开 发展环境 Eclipse可以,我怀疑它 Eclipse(或ADT)未经检查 插件)由于一些小故障。
  2. 在应用程序项目中,我 忽略了添加我的图书馆项目 作为Add...的参考 按钮。 (我多么愚蠢?)
  3. 我希望像我这样的其他新手会发现这些信息有用。有时,一个非常难以调试的问题,当无辜的毫无戒心的强调程序员认为这已经被照顾时,隐藏了一个配置错误......

答案 3 :(得分:0)

我在其中一个项目中遇到了同样的错误,并认为我可以分享我如何修复我的。

在我的项目的某些时候,我必须更改我正在使用的所有Activity类所在的包名称之一。当我这样做时,我忘了更新AndroidManifest,这导致了我同样的错误。更新此修复它。