想了解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 5.x 系统 ClassNotFoundException 的坑
- Android ClassNotFoundException:在路径上找不到类
- Android java.lang.ClassNotFoundException
- Android java.lang.ClassNotFoundException:未找到类
Android模拟器崩溃:启动时出现“Dx bad class file magic”/ ClassNotFoundException?(android打开模拟器失败)
当我运行它时,如果我刚刚清理它,我会收到警告,说每个类文件都有Dx坏类文件魔法(cafebabe)或版本(0033.0000)(否则我不会收到这些警告)我认为这可能就是为什么它在启动时崩溃了.我到处寻找并尝试了不同的东西,但没有.
另一个需要注意的重要事项是,我能够在我的新计算机上从eclipse中的示例创建一个android项目,一切都运行得很好.所以出于某种原因,svn搞砸了?感谢您的帮助,如果需要更多信息,请与我们联系.
编辑:忘了提到我有另一个项目在svn我用作框架和游戏引用该项目.也许他们正在编译为不同的java版本?
解决方法
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:在路径上找不到类
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
我知道在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的新手,所以希望有人可以帮助我。
按照以下步骤操作(在android studio中):
- 转到build菜单。
- 通过单击清理项目来清理项目。
- 通过单击make project来构建项目。
此过程称为 干净的构建 ,通常在添加一些依赖项之后完成。
关于Android模拟器崩溃:启动时出现“Dx bad class file magic”/ ClassNotFoundException?和android打开模拟器失败的介绍现已完结,谢谢您的耐心阅读,如果想了解更多关于Android 5.x 系统 ClassNotFoundException 的坑、Android ClassNotFoundException:在路径上找不到类、Android java.lang.ClassNotFoundException、Android java.lang.ClassNotFoundException:未找到类的相关知识,请在本站寻找。
本文标签: