原文地址:http://blog.csdn.net/sayid_des/article/details/50462261
今天在Android开发时候,遇到奇怪的问题。相同的程序,运行在一部分手机上没有问题。运行到另外个别手机上总是出现以下错误:
Process: com.yijiaoxing.organizationsss, PID: 22705
java.lang.NoClassDefFoundError: org.apache.commons.collections.map.UnmodifiableMap
at org.apache.commons.collections.MapUtils.<clinit>(MapUtils.java:96)
at com.yijiaoxing.organization.ui.TuijianFragment.initFragment(TuijianFragment.java:219)
at com.yijiaoxing.organization.ui.TuijianFragment.setChangelView(TuijianFragment.java:96)
at com.yijiaoxing.organization.ui.TuijianFragment.initSetData(TuijianFragment.java:257)
at net.tycmc.bulb.bases.ui.BaseFragment.onCreateView(BaseFragment.java:32)
at android.support.v4.app.Fragment.performCreateView(Fragment.java:2087)
at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1113)
at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1295)
at android.support.v4.app.BackStackRecord.run(BackStackRecord.java:801)
at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1682)
at android.support.v4.app.FragmentController.execPendingActions(FragmentController.java:388)
at android.support.v4.app.FragmentActivity.onStart(FragmentActivity.java:607)
at android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1171)
at android.app.Activity.performStart(Activity.java:5259)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2174)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2250)
at android.app.ActivityThread.access$900(ActivityThread.java:141)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1213)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:136)
at android.app.ActivityThread.main(ActivityThread.java:5072)
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:793)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:609)
at dalvik.system.NativeStart.main(Native Method)
查找了好久,总是也无法解决。后来查到解决办法是:
由于build.gradle文件里已经声明了 multiDexEnabled true
。可以解决65535无法运行问题。(声明原因:当你的程序达到65535个的时候,程序将运行不起来了。不太好处理。这也是好多人从eclipse 转到 Studio的其中一个原因 )当方法数超过65535时便会自动打出两个Dex包命名为 classes.dex
classes2.dex
,一些方法被打入了第二个dex包,即classes2.dex
中,导致了5.0以下机型无法运行应用报错。
下面是解决方案:
1.在defaultConfig
中已经声明 multiDexEnabled true
用于启用MultiDex
2.在依赖中添加 compile 'com.android.support:multidex:1.0.1'
支持包用于5.0以下系统
3.如果你的工程中已经含有Application类,那么让它继承android.support.multidex.MultiDexApplication类,如果你的Application已经继承了其他类并且不想做改动,那么还有另外一种使用方式,覆写attachBaseContext()方法:
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 1
- 2
- 3
- 4
- 5
- 6
- 7