6

我在开发周期中看到过几次以下错误,现在我刚刚收到错误报告。我不知道是什么原因造成的。在阅读了本网站上有关此问题的类似问题后,我仔细检查了我的 AndroidManifest,一切看起来都很好。关于什么可能导致此异常的任何想法?

java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.jerrellmardis.ridecta/com.jerrellmardis.ridecta.ui.StopTimesActivity}: java.lang.ClassNotFoundException: com.jerrellmardis.ridecta.ui.StopTimesActivity
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1983)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2084)
at android.app.ActivityThread.access$600(ActivityThread.java:130)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1195)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4745)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.ClassNotFoundException: com.jerrellmardis.ridecta.ui.StopTimesActivity
at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:61)
at java.lang.ClassLoader.loadClass(ClassLoader.java:501)
at java.lang.ClassLoader.loadClass(ClassLoader.java:461)
at android.app.Instrumentation.newActivity(Instrumentation.java:1053)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1974)
... 11 more

另一件需要注意的事情是,我正在使用https://github.com/petedoyle/android-support-v4-googlemaps上的 android-support-v4-googlemaps 库,它允许我在片段中嵌入 MapView(以及与 ActionBarSherlock 库)。这个异常似乎是一个依赖问题,我不确定它是否与我使用上述库的方式有关。

这是清单文件:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.jerrellmardis.ridecta"
    android:installLocation="internalOnly"
    android:versionCode="11"
    android:versionName="1.0.2">
    <uses-sdk
        android:minSdkVersion="10"
        android:targetSdkVersion="16"/>
    <uses-permission android:name="android.permission.INTERNET"/>
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
    <uses-permission android:name="android.permission.READ_PHONE_STATE"/>
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>
    <uses-permission android:name="android.permission.VIBRATE"/>
    <uses-permission android:name="android.permission.WAKE_LOCK"/>
    <uses-permission android:name="com.android.vending.BILLING"/>
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
    <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED"/>
    <application
        android:name=".RideCtaApplication"
        android:allowBackup="true"
        android:backupAgent=".backup.RideCtaBackupAgentHelper"
        android:hardwareAccelerated="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:logo="@drawable/logo">
        <uses-library android:name="com.google.android.maps"/>
        <activity
            android:name=".ui.HomeActivity"
            android:configChanges="orientation|keyboardHidden|screenSize"
            android:label="@string/app_name"
            android:theme="@style/Theme.RideCta.LogoOnly">
            <intent-filter>
                <action android:name="android.intent.action.MAIN"/>
                <category android:name="android.intent.category.LAUNCHER"/>
            </intent-filter>
        </activity>
        <activity
            android:name=".ui.BusDirectionsActivity"
            android:label="@string/app_name"
            android:theme="@style/Theme.RideCta"/>
        <activity
            android:name=".ui.StopsActivity"
            android:label="@string/app_name"
            android:theme="@style/Theme.RideCta"/>
        <activity
            android:name=".ui.StopTimesActivity"
            android:label="@string/app_name"
            android:theme="@style/Theme.RideCta.Split"
            android:uiOptions="splitActionBarWhenNarrow"/>
        <activity
            android:name=".ui.TrainDirectionsActivity"
            android:label="@string/app_name"
            android:theme="@style/Theme.RideCta"/>
        <activity
            android:name=".ui.LiveMapActivity"
            android:label="@string/app_name"
            android:theme="@style/Theme.RideCta.Transparent"/>
        <activity
            android:name=".ui.ServiceAlertsActivity"
            android:label="@string/app_name"
            android:theme="@style/Theme.RideCta"/>
        <activity
            android:name=".ui.SearchActivity"
            android:exported="true"
            android:launchMode="singleTop"
            android:theme="@style/Theme.RideCta">
            <intent-filter>
                <action android:name="android.intent.action.SEARCH"/>
                <category android:name="android.intent.category.DEFAULT"/>
            </intent-filter>
            <meta-data
                android:name="android.app.searchable"
                android:resource="@xml/searchable"/>
        </activity>
        <activity
            android:name=".ui.PreferenceActivity"
            android:label="@string/app_name"
            android:theme="@style/Theme.Preference"/>
        <activity
            android:name=".ui.LegacyPreferenceActivity"
            android:label="@string/app_name"
            android:theme="@style/Theme.Preference"/>
        <activity
            android:name="com.google.ads.AdActivity"
            android:configChanges="keyboard|keyboardHidden|orientation|screenLayout|uiMode|screenSize|smallestScreenSize"/>
        <receiver android:name=".receiver.ReminderAlarmReceiver"/>
        <receiver android:name=".receiver.ReminderBootReceiver">
            <intent-filter>
                <action android:name="android.intent.action.BOOT_COMPLETED"/>
            </intent-filter>
        </receiver>
        <receiver android:name="net.robotmedia.billing.BillingReceiver">
            <intent-filter>
                <action android:name="com.android.vending.billing.IN_APP_NOTIFY"/>
                <action android:name="com.android.vending.billing.RESPONSE_CODE"/>
                <action android:name="com.android.vending.billing.PURCHASE_STATE_CHANGED"/>
            </intent-filter>
        </receiver>
        <service android:name=".service.ReminderService"/>
        <service android:name="net.robotmedia.billing.BillingService"/>
        <meta-data
            android:name="android.app.default_searchable"
            android:value=".ui.SearchActivity"/>
        <meta-data
            android:name="com.google.android.backup.api_key"
            android:value="<REMOVED>"/>
        <provider
            android:name=".provider.SearchProvider"
            android:authorities="com.jerrellmardis.ridecta.provider.SearchProvider"/>
    </application>
</manifest>
4

9 回答 9

5

右键单击您的项目文件夹 => 属性 => Java 构建路径 => 订购和导出 => 如果未选中,请选中“Android Private Libraries”框。做一个干净的。它有效!

于 2013-06-21T14:13:37.560 回答
2

系统无法找到您的类文件。因此,清单文件中的类名规范有问题,或者您的类存在于您可以指定的某些不同的包中。

尝试清理和重建您的代码。有时我们需要在更新代码时进行清理。

也没有人可以通过阅读你的 logcat 来找到错误。所以最好发布你的清单文件和所有的类名。

于 2012-11-07T07:21:32.207 回答
1

根据我的经验,如果您看到与无法加载您绝对知道的资源或类相关的奇怪异常,则问题可能与将活动推得太接近其内存限制有关。在开发过一些需要大量内存的应用程序之后,我可以说我已经看到许多“在野外”报告的异常情况与没有找到我知道的正确包含在生产构建中的资源有关。

一般来说,在这些情况下,堆栈跟踪永远不会 100% 相同,因此如果您始终看到相同的缺失类,则可能是您的构建或项目配置有错误。进行全面重建(正如其他人也建议的那样)可能会有所帮助。

否则,我建议使用Crittercism 之类的服务,以便在崩溃发生之前获取有关设备的更准确信息。

于 2012-11-14T14:47:09.693 回答
1

将活动添加到清单文件为..

<activity android:name=".FSRRemarks" >
        </activity>

如果您已经添加了它,请尝试清理构建您的项目,然后运行

于 2012-11-07T07:03:59.333 回答
1

请按照以下步骤操作:-

1> 从参考库中删除外部 jar。不要在此处再次添加它们。

2> 在您的项目中创建另一个文件夹“libs”。

3> 将您的 jar 复制并粘贴到“libs”文件夹中。

4> 清理并重新运行应用程序。

希望它有效。

于 2012-11-15T12:22:02.923 回答
0

您在哪里复制了 android-support-v4-googlemaps.jar 文件?在 actionbarsherlock/library/libs 里面?还是在 your_app/libs 中?

仔细检查您是否没有包含两个不同版本的支持库(一个带有地图,另一个没有地图)

于 2012-11-18T06:57:20.513 回答
0

如果您已经将 Activity 添加到 AndroidManifest,并且该 Activity 确实存在于您的项目中,我建议您只需清理并重建然后重试。但是我遇到了另一个奇怪的问题,就是Ecplise构建的apk文件会崩溃并报“ClassNotFoundException with applicaion”的问题,而ant构建的apk文件可以正常运行,没有问题。

所以也许你也可以尝试使用ant来构建它,通过命令“android update project -p.”。

于 2012-11-07T07:00:31.260 回答
0

为避免此类错误,请在需要创建新类时按照以下步骤操作;

  1. 双击包资源管理器中的 AndroidManifest.xml。
  2. 单击清单编辑器的“应用程序”选项卡
  3. 单击“应用程序节点”标题下的“添加..”(屏幕左下角)
  4. 从弹出的对话框中的列表中选择 Activity(如果有选项,则要创建一个新的顶级元素)
  5. 单击“Attributes for”标题(窗口右下方)下的“Name*”链接,为新活动创建一个类。
  6. 当您从新课程对话框中单击完成时,它将带您进入新的活动课程,以便您开始编码。

只需从您的活动中复制您的代码,删除文件并像这样重新创建它,所有与配置相关的问题都会得到解决。

于 2012-11-07T07:03:44.687 回答
0

看来我已经通过不使用 android-support-v4-googlemaps 库解决了这个问题。我将我的应用程序更改为在 Fragment 中使用 Map 的 ImageView,然后在用户单击地图图像后使用普通的旧 MapActivity。自从这样做以来,我没有注意到任何 RuntimeExceptions。

于 2012-11-24T19:12:52.210 回答