我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.
找到这个有用的线程后终于解决了:
我isResumed()
在班上创建了一个方法.
public boolean isResumed(){ return isResumed; }
我删除/编辑后立即恢复正常.我没有在文档中Activity
或AppCompatActivity
文档中找到此方法.