您的位置:首页 > 移动开发 > Android开发

Android 出现java.lang.NoClassDefFoundError错误的一种解决方案

2017-04-26 19:16 746 查看
原文地址: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()方法:
public class MyApplication extends FooApplication {
@Override
protected void attachBaseContext(Context base) {
super.attachBaseContext(base);
MultiDex.install(this);
}
}
1
2
3
4
5
6
7


1
2
3
4
5
6
7
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐