GVKun编程网logo

Android模拟器崩溃:启动时出现“Dx bad class file magic”/ ClassNotFoundException?(android打开模拟器失败)

14

想了解Android模拟器崩溃:启动时出现“Dxbadclassfilemagic”/ClassNotFoundException?的新动态吗?本文将为您提供详细的信息,我们还将为您解答关于andro

想了解Android模拟器崩溃:启动时出现“Dx bad class file magic”/ ClassNotFoundException?的新动态吗?本文将为您提供详细的信息,我们还将为您解答关于android打开模拟器失败的相关问题,此外,我们还将为您介绍关于Android 5.x 系统 ClassNotFoundException 的坑、Android ClassNotFoundException:在路径上找不到类、Android java.lang.ClassNotFoundException、Android java.lang.ClassNotFoundException:未找到类的新知识。

本文目录一览:

Android模拟器崩溃:启动时出现“Dx bad class file magic”/ ClassNotFoundException?(android打开模拟器失败)

Android模拟器崩溃:启动时出现“Dx bad class file magic”/ ClassNotFoundException?(android打开模拟器失败)

我正在开发一个 Android游戏,我有一个问题.我让我的游戏在我的另一台计算机上完全运行,所以我将项目提交到svn服务器,以便在我的新Windows 7 64位计算机上使用.我在我的新电脑上检查了它,并且在eclipse中具有颠覆性.显然我在构建路径上遇到了一些问题所以我修复了这些问题,而且项目没有错误.当我在运行android 2.3.3的模拟器上运行它时,它会在启动时因主要活动的ClassNotFoundException而崩溃.我在清单中有一切正确.
当我运行它时,如果我刚刚清理它,我会收到警告,说每个类文件都有Dx坏类文件魔法(cafebabe)或版本(0033.0000)(否则我不会收到这些警告)我认为这可能就是为什么它在启动时崩溃了.我到处寻找并尝试了不同的东西,但没有.
另一个需要注意的重要事项是,我能够在我的新计算机上从eclipse中的示例创建一个android项目,一切都运行得很好.所以出于某种原因,svn搞砸了?感谢您的帮助,如果需要更多信息,请与我们联系.

编辑:忘了提到我有另一个项目在svn我用作框架和游戏引用该项目.也许他们正在编译为不同的java版本?

解决方法

想通过留下的评论想出来!我所拥有的另一个框架项目是我在游戏项目中引用的,就像我在编辑中提到的那样.事实证明,即使游戏项目是1.6,该框架上的sdk级别是1.7而不是1.6.由于某种原因,android没有检测到它并且它把所有东西都扔掉了.在我将每个项目更改为1.6并清理每个项目后,它都工作了!谢谢!

Android 5.x 系统 ClassNotFoundException 的坑

Android 5.x 系统 ClassNotFoundException 的坑

    Android 5.x 的 ART 虚拟机处理 dex 文件的时候,只处理了 classes.dex-classes99.dex,超过部分丢弃,具体源码可以查看这里,在编译的时候默认 dexOption.preDexLibraries=true,如果依赖了太多的 lib,每个 lib 编译成一个 dex,导致 app 中有超过 100 个 dex,使用 5.x 手机作为开发机的时候就会出现莫名其妙的 ClassNotFoundException,只需要在 App 的 build.gradle 中 android 下添加 dexOptions {preDexLibraries=false} 即可

Android ClassNotFoundException:在路径上找不到类

Android ClassNotFoundException:在路径上找不到类

10-22 15:29:40.897: E/AndroidRuntime(2561): FATAL EXCEPTION: main10-22 15:29:40.897: E/AndroidRuntime(2561): java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.gvg.simid/com.gvg.simid.Login}: java.lang.ClassNotFoundException: Didn''t find class "com.gvg.simid.Login" on path: DexPathList[[zip file "/data/app/com.gvg.simid-1.apk"],nativeLibraryDirectories=[/data/app-lib/com.gvg.simid-1, /vendor/lib, /system/lib]]10-22 15:29:40.897: E/AndroidRuntime(2561):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2137)10-22 15:29:40.897: E/AndroidRuntime(2561):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2261)10-22 15:29:40.897: E/AndroidRuntime(2561):     at android.app.ActivityThread.access$600(ActivityThread.java:141)10-22 15:29:40.897: E/AndroidRuntime(2561):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1256)10-22 15:29:40.897: E/AndroidRuntime(2561):     at android.os.Handler.dispatchMessage(Handler.java:99)10-22 15:29:40.897: E/AndroidRuntime(2561):     at android.os.Looper.loop(Looper.java:137)10-22 15:29:40.897: E/AndroidRuntime(2561):     at android.app.ActivityThread.main(ActivityThread.java:5103)10-22 15:29:40.897: E/AndroidRuntime(2561):     at java.lang.reflect.Method.invokeNative(Native Method)10-22 15:29:40.897: E/AndroidRuntime(2561):     at java.lang.reflect.Method.invoke(Method.java:525)10-22 15:29:40.897: E/AndroidRuntime(2561):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737)10-22 15:29:40.897: E/AndroidRuntime(2561):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)10-22 15:29:40.897: E/AndroidRuntime(2561):     at dalvik.system.NativeStart.main(Native Method)10-22 15:29:40.897: E/AndroidRuntime(2561): Caused by: java.lang.ClassNotFoundException: Didn''t find class "com.gvg.simid.Login" on path: DexPathList[[zip file "/data/app/com.gvg.simid-1.apk"],nativeLibraryDirectories=[/data/app-lib/com.gvg.simid-1, /vendor/lib, /system/lib]]10-22 15:29:40.897: E/AndroidRuntime(2561):     at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:53)10-22 15:29:40.897: E/AndroidRuntime(2561):     at java.lang.ClassLoader.loadClass(ClassLoader.java:501)10-22 15:29:40.897: E/AndroidRuntime(2561):     at java.lang.ClassLoader.loadClass(ClassLoader.java:461)10-22 15:29:40.897: E/AndroidRuntime(2561):     at android.app.Instrumentation.newActivity(Instrumentation.java:1061)10-22 15:29:40.897: E/AndroidRuntime(2561):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2128)10-22 15:29:40.897: E/AndroidRuntime(2561):     ... 11 more

我不太确定是什么原因导致的,因为清单中正确列出了它:

<?xml version="1.0" encoding="utf-8"?><manifest xmlns:android="http://schemas.android.com/apk/res/android"    package="com.gvg.simid"    android:versionCode="1"    android:versionName="1.0" >    <uses-sdk        android:minSdkVersion="8"        android:targetSdkVersion="18" />    <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />    <uses-permission android:name="android.permission.BLUETOOTH" />    <uses-permission android:name="android.permission.BLUETOOTH_ADMIN" />    <uses-permission android:name="android.permission.CAMERA"/>    <uses-permission android:name="android.permission.CHANGE_WIFI_STATE"/>    <uses-permission android:name="android.permission.INTERNET" />    <uses-permission android:name="android.permission.READ_LOGS" />    <uses-permission android:name="android.permission.READ_OWNER_DATA" />    <uses-permission android:name="android.permission.READ_PHONE_STATE" />    <uses-permission android:name="android.permission.RECORD_AUDIO"/>    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />    <uses-permission android:name="android.permission.WRITE_OWNER_DATA" />    <uses-permission android:name="android.permission.WRITE_SETTINGS" />    <uses-permission android:name="android.permission.WAKE_LOCK" />    <uses-feature android:name="android.hardware.usb.host" />    <application        android:allowBackup="true"        android:icon="@drawable/ic_launcher"        android:label="@string/app_name"        android:theme="@style/AppTheme" >        <activity            android:name="com.gvg.simid.Login"            android:label="@string/app_name"             android:screenOrientation="landscape">            <intent-filter>                <action android:name="android.intent.action.MAIN" />                <category android:name="android.intent.category.LAUNCHER" />            </intent-filter>        </activity>    </application></manifest>

我还添加了“ Android Private Libraries”来构建路径,并将其移至“ Order and Export”的顶部,但是它仍然给我同样的错误。

编辑:我完全重建了该项目,并且无法重现该错误。不知道是什么原因造成的。

答案1

小编典典

我的项目有同样的问题。这是由于我的项目与我在项目中添加的库项目之间的android支持库版本冲突而发生的。将相同版本的android支持库放入您的项目和包含的库项目中,并清理构建 …一切正常。

Android java.lang.ClassNotFoundException

Android java.lang.ClassNotFoundException

我知道在SO上有很多问题,但遗憾的是没有一个答案能解决我的问题.

我有3个用于测试模拟器的Android设备,我的应用程序在所有这些设备上工作正常,但是当我发布应用程序时,我收到此错误(仅在少数设备上,而不是全部):

java.lang.RuntimeException: Unable to start activity ComponentInfo{<package>/<package>.<ProjectName>Activity}: android.view.InflateException: Binary XML file line #10: Error inflating class <package>.MainSurfaceView
 at android.app.ActivityThread.performlaunchActivity(ActivityThread.java:2663)
 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:860)
 at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
 at dalvik.system.NativeStart.main(Native Method)
Caused by: android.view.InflateException: Binary XML file line #10: Error inflating class <package>.MainSurfaceView
 at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:576)
 at android.view.LayoutInflater.rInflate(LayoutInflater.java:618)
 at android.view.LayoutInflater.inflate(LayoutInflater.java:407)
 at android.view.LayoutInflater.inflate(LayoutInflater.java:320)
 at android.view.LayoutInflater.inflate(LayoutInflater.java:276)
 at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:198)
 at android.app.Activity.setContentView(Activity.java:1647)
 at <package>.<ProjectName>Activity.onCreate(UnkNown Source)
 at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
 at android.app.ActivityThread.performlaunchActivity(ActivityThread.java:2627)
 ... 11 more
Caused by: java.lang.classNotFoundException: <package>.MainSurfaceView in loader dalvik.system.PathClassLoader[/data/app/<package>-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.view.LayoutInflater.createView(LayoutInflater.java:466)
 at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:565)

该类扩展了类GLSurfaceView并且有3个构造函数(GLSurfaceView仅支持2个,但我在SO上读到缺少的第三个可能导致问题 – 它没有).

类(仅构造函数):

public class MainSurfaceView extends GLSurfaceView {

    public MainSurfaceView(Context context) {
        super(context);
    }

    public MainSurfaceView(Context context, AttributeSet attrs){
        super(context, attrs);
    }

    public MainSurfaceView(Context context, AttributeSet attrs, int defStyle){
        super(context, attrs);
    }
}

添加构造函数

public MainSurfaceView(Context context, AttributeSet attrs, int defStyle){
    super(context, attrs);
}

没有解决问题.

我的清单文件:

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

    <supports-screens android:largeScreens="true"
                      android:anyDensity="true"
                      android:normalScreens="true"
                      android:smallScreens="true"
                      android:resizeable="true" />


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

    <application android:icon="@drawable/icon" android:label="@string/app_name">
        <activity android:name=".<project>Activity"
                  android:label="@string/app_name"
                  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:theme="@android:style/Theme.NoTitleBar.Fullscreen"
            android:configChanges="keyboard|keyboardHidden|orientation" />

    </application>
</manifest>

我的布局文件:

<?xml version="1.0" encoding="utf-8"?>
<FrameLayout
  xmlns:android="http://schemas.android.com/apk/res/android"
  xmlns:ads="http://schemas.android.com/apk/lib/com.google.ads"
  android:orientation="vertical"
  android:layout_width="480dp"
  android:layout_height="800dp"
  android:layout_gravity="center">

    <<package>.MainSurfaceView android:id="@+id/glSurface" android:layout_width="fill_parent"
         android:layout_height="fill_parent" android:layout_gravity="top|left"/>

  <com.google.ads.AdView android:id="@+id/adView"
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content"
    android:layout_gravity="bottom"
    android:visibility="visible"
    android:layout_alignParentTop="true"
    ads:adSize="BANNER"
    ads:adUnitId="<id>"
    ads:loadAdOnCreate="true"/>

</FrameLayout>

谢谢你的帮助.如果有人能告诉我如何重新创建错误,那将会非常有帮助.

解决方法:

如果您已更新到ADTv17或更高版本,旧的ProGuard文件将对您执行此操作.创建一个新的空项目,并查看project.properties和proguard-properties并相应地修改当前项目.

Android java.lang.ClassNotFoundException:未找到类

Android java.lang.ClassNotFoundException:未找到类

考虑您的报价,

我在这里是Android的新手,所以希望有人可以帮助我。

按照以下步骤操作(在android studio中):

  1. 转到build菜单。
  2. 通过单击清理项目来清理项目。
  3. 通过单击make project来构建项目。

此过程称为 干净的构建 ,通常在添加一些依赖项之后完成。

关于Android模拟器崩溃:启动时出现“Dx bad class file magic”/ ClassNotFoundException?android打开模拟器失败的介绍现已完结,谢谢您的耐心阅读,如果想了解更多关于Android 5.x 系统 ClassNotFoundException 的坑、Android ClassNotFoundException:在路径上找不到类、Android java.lang.ClassNotFoundException、Android java.lang.ClassNotFoundException:未找到类的相关知识,请在本站寻找。

本文标签: