我在我的应用中使用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()
中添加了一个名为MainActivity
的方法,这就是(Native Method)
错误的原因,与4.4相差6.0。
答案 0 :(得分:22)
在找到this有用的帖子后终于解决了:
我在班上创建了一个方法isResumed()
。
public boolean isResumed(){
return isResumed;
}
我删除/编辑后立即恢复正常。我在文档中的Activity
或AppCompatActivity
中找不到此方法。
答案 1 :(得分:1)
与基类之一冲突的函数名称。将您的函数重命名为自定义函数,即isBaseResumed()