ADT升级后Compile ExceptionUnable to instantiate activity ComponentInfo

简介:

今天将ADT升级后(adnroid SDK Tools从20升级到22, Android SDK Build-tools升级到17),突然所有程序不能启动了,报找不到R类,然后layout并没有错误,bin文件夹下也没有生成R.java类,后发现是Android SDK Tools等没有安装。

在Android SDK Manager中安装完Tools文件夹下tools后依然不能启动,异常如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

E/AndroidRuntime(12439): FATAL EXCEPTION: main

E/AndroidRuntime(12439): java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{cn.trinea.android.demo/cn.trinea.android.demo.MainActivity}: java.lang.ClassNotFoundException: Didn't find class "cn.trinea.android.demo.MainActivity" on path: DexPathList[dexElements=[zip file "/data/app/cn.trinea.android.demo-1.apk"],nativeLibraryDirectories=[/data/app-lib/cn.trinea.android.demo-1, /vendor/lib, /system/lib]]

E/AndroidRuntime(12439): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2382)

E/AndroidRuntime(12439): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2520)

E/AndroidRuntime(12439): at android.app.ActivityThread.access$600(ActivityThread.java:168)

E/AndroidRuntime(12439): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1360)

E/AndroidRuntime(12439): at android.os.Handler.dispatchMessage(Handler.java:99)

E/AndroidRuntime(12439): at android.os.Looper.loop(Looper.java:153)

E/AndroidRuntime(12439): at android.app.ActivityThread.main(ActivityThread.java:5508)

E/AndroidRuntime(12439): at java.lang.reflect.Method.invokeNative(Native Method)

E/AndroidRuntime(12439): at java.lang.reflect.Method.invoke(Method.java:511)

E/AndroidRuntime(12439): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:835)

E/AndroidRuntime(12439): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:602)

E/AndroidRuntime(12439): at dalvik.system.NativeStart.main(Native Method)

E/AndroidRuntime(12439): Caused by: java.lang.ClassNotFoundException: Didn't find class "cn.trinea.android.demo.MainActivity" on path: DexPathList[dexElements=[zip file "/data/app/cn.trinea.android.demo-1.apk"],nativeLibraryDirectories=[/data/app-lib/cn.trinea.android.demo-1, /vendor/lib, /system/lib]]

E/AndroidRuntime(12439): at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:53)

E/AndroidRuntime(12439): at java.lang.ClassLoader.loadClass(ClassLoader.java:501)

E/AndroidRuntime(12439): at java.lang.ClassLoader.loadClass(ClassLoader.java:461)

E/AndroidRuntime(12439): at android.app.Instrumentation.newActivity(Instrumentation.java:1054)

E/AndroidRuntime(12439): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2373)

E/AndroidRuntime(12439): ... 11 more

解决方法:

菜单Project -> Properties -> Java Build Path -> Order & Export, 然后选中Android Private Libraries, 菜单 Project->Clean,然后运行程序即可。

如果依然失败,将相关的依赖工程选中Android Private Libraries并clean然后重试即可

PS:

新版的ADT加快了插件启动速度,增加了Dump View Hierarchy for UI Automator使得界面查看更方便,Capature System Wide Trace貌似是用来性能调优的,不过不支持windows,后面详细了解看看

目录
相关文章
|
5月前
|
Android开发
解決Android报错:Could not initialize class org.codehaus.groovy.reflection.ReflectionCache
解決Android报错:Could not initialize class org.codehaus.groovy.reflection.ReflectionCache
148 1
|
5月前
|
开发工具 Android开发
解决Manifest merger failed : android:exported needs to be explicitly specified for <activity>
解决Manifest merger failed : android:exported needs to be explicitly specified for <activity>
135 1
|
Android开发
【错误记录】Android Studio 编译报错 ( Cannot use connection to Gradle distribution . as it has been stopped. )
【错误记录】Android Studio 编译报错 ( Cannot use connection to Gradle distribution . as it has been stopped. )
821 0
【错误记录】Android Studio 编译报错 ( Cannot use connection to Gradle distribution . as it has been stopped. )
|
Android开发
【错误记录】Android 应用中启动 FlutterActivity 报错 ( have you declared this activity in your AndroidManifest )
【错误记录】Android 应用中启动 FlutterActivity 报错 ( have you declared this activity in your AndroidManifest )
603 0
【错误记录】Android 应用中启动 FlutterActivity 报错 ( have you declared this activity in your AndroidManifest )
|
Android开发
【错误记录】Android Studio 编译报错 ( Could not find com.android.tools.build:gradle:4.2.1. )
【错误记录】Android Studio 编译报错 ( Could not find com.android.tools.build:gradle:4.2.1. )
768 0
【错误记录】Android Studio 编译报错 ( Could not find com.android.tools.build:gradle:4.2.1. )
|
Android开发
【错误记录】Android Studio 编译报错 ( AppCompat does not support the current theme features )
【错误记录】Android Studio 编译报错 ( AppCompat does not support the current theme features )
308 0
【错误记录】Android Studio 编译报错 ( AppCompat does not support the current theme features )
|
Android开发
DSL element ‘android.dataBinding.enabled‘ is obsolete and has been replaced with ‘android.buildFeatu
DSL element ‘android.dataBinding.enabled‘ is obsolete and has been replaced with ‘android.buildFeatu
226 0
|
Android开发
Android中gradle文件中implementation和compile的异同
相同之处:都是为Module添加依赖 不同之处:implementation不可以依赖传递,但是compile可以依赖传。这是什么意思呢?有经验的开发人员基本上都了解,举个例子,如果一个App依赖于libA,libA又依赖...
1336 0