当前位置:  开发笔记 > 编程语言 > 正文

java.lang.LinkageError:MainActivity

如何解决《java.lang.LinkageError:MainActivity》经验,为你挑选了1个好方法。

productFlavours在我的应用中使用.我也在使用multi dex.

 defaultConfig {
         multiDexEnabled true
         minSdkVersion 17
         targetSdkVersion 22
         ... 
 }

productFlavors {
  prodFlavor1{...}
  prodFlavor2{...}
 }

dependencies {
    compile 'com.android.support:multidex:1.0.1'
...
}

在Application类中:

@Override
    public void onCreate() {
        MultiDex.install(getApplicationContext());
        super.onCreate();
}

我为5以下版本的Android版本添加了以上代码.

然后,下面的结构,有两个略有不同的版本MainActivity(MainActivity扩展AppCompatActivity)在应用程序的某个时刻开始,按下按钮.

app/src/prodFlavor1/.../MainActivity
app/src/prodFlavor2/.../MainActivity

prodFlavor1,MainActivity之后立即开始SplashActivity.在prodFlavor2,MainActivity.

这之前很长一段时间,甚至在我添加了这部分之后multidex,但突然弯腰工作,没有任何解释.即使我删除了引用multidex的代码,我也会得到同样的东西.

当我切换到prodVersion2一切正常.但当我切换到prodVersion1我得到:

startActivity(new Intent(TutorialActivity.this,MainActivity.class));

适用于Android 6的Nexus 5:

Process: com.mpackage, PID: 30807
                                                             java.lang.LinkageError: com.mpackage.activities.MainActivity
                                                                 at dalvik.system.DexFile.defineClassNative(Native Method)
                                                                 at dalvik.system.DexFile.defineClass(DexFile.java:226)
                                                                 at dalvik.system.DexFile.loadClassBinaryName(DexFile.java:219)
                                                                 at dalvik.system.DexPathList.findClass(DexPathList.java:338)
                                                                 at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:54)
                                                                 at java.lang.ClassLoader.loadClass(ClassLoader.java:511)
                                                                 at java.lang.ClassLoader.loadClass(ClassLoader.java:469)
                                                                 at com.gossip.activities.TutorialActivity$1.handleMessage(TutorialActivity.java:52)
                                                                 at android.os.Handler.dispatchMessage(Handler.java:102)
                                                                 at android.os.Looper.loop(Looper.java:148)
                                                                 at android.app.ActivityThread.main(ActivityThread.java:5417)
                                                                 at java.lang.reflect.Method.invoke(Native Method)
                                                                 at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
                                                                 at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)

在Android 4.4的Nexus4仿真器上:

java.lang.NoClassDefFoundError: com.mpackage.activities.MainActivity
                                                               at com.gossip.activities.TutorialActivity$1.handleMessage(TutorialActivity.java:52)
                                                               at android.os.Handler.dispatchMessage(Handler.java:102)
                                                               at android.os.Looper.loop(Looper.java:136)
                                                               at android.app.ActivityThread.main(ActivityThread.java:5017)
                                                               at java.lang.reflect.Method.invokeNative(Native Method)
                                                               at java.lang.reflect.Method.invoke(Method.java:515)
                                                               at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
                                                               at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
                                                               at dalvik.system.NativeStart.main(Native Method)

更新:

似乎错误是由于我添加了一个名为isResumed()in in 的事实引起的MainActivity,这就是为什么(Native Method)错误,与4.4不同的6.0.



1> AlexAndro..:

找到这个有用的线程后终于解决了:

isResumed()在班上创建了一个方法.

public boolean isResumed(){
    return isResumed;
}

我删除/编辑后立即恢复正常.我没有在文档中ActivityAppCompatActivity文档中找到此方法.


它隐藏在文档中,是的(参见@hide).但您可以在源代码中找到它:https://github.com/android/platform_frameworks_base/blob/master/core/java/android/app/Activity.java#L6432
推荐阅读
mobiledu2402851173
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有