一.概述

       如今越来越多的app開始採用本地app结合html5的设计结构,这样做不仅能够跨平台,而且在某个业务或模块出了严重的bug,能够直接在html5+后台实时修复,省去了公布新包和新版本号的步骤.那么在不是html5结构的android app中怎么实现不又一次打包更新版本号的情况下实现热修复bug呢?这里介绍的一种方法是通过升级dex文件来修复线上包的紧急bug。

二.实例

       该实例是之前一篇 Android源代码之DeskClock(三) Proxy/Delegate Application 框架应用 的延伸.

       这篇讲关于热修复採用的是Proxy/Delegate Application 框架.

       主要实现的流程:

       1.替换主程序dex文件为代理启动程序的dex文件

       2.代理启动程序启动后,动态载入主程序dex

       3.ProxyApplication替换消除本身Context引用为MyApplication

       4.启动主程序的Application.

       经过上述的步骤处理,因为程序启动dex仅仅是一个代理,而主程序的dex是动态载入的,所以就能够达到不升级主程序不更改版本仅仅升级dex文件来修复线上紧急bug的目的.

       由于这里使用了两个dex文件,所以就要把之前博客里面的ProxyApplication整个剥离出来,作为一个Module,跟主程序同级.

                                                           

       之前那篇博客由于没有替换ClassLoader的需求,所以在MyProxyApplication中复写了一个空的attachBaseContext方法,这里就须要在attachBaseContext反射替换MyProxyApplication的ClassLoader的父类的实例为主程序dex的DexClassLoader,这样既能动态载入主dex,有能让外部包含DelegateApplication自身都以为DelegateApplication是程序的第一个入口.

        ClassLoader curLoader = ctx.getClassLoader();
        DexClassLoader parentLoader = new DexClassLoader(dexPath, outputDir.getAbsolutePath(), nativeLibraryDir, curLoader.getParent());
        Field f = ClassLoader.class.getDeclaredField("parent");
        f.setAccessible(true);
        f.set(curLoader, parentLoader);
       这个时候主程序的dex文件就在其它路径下放着,等待代理启动dex来载入他,这样就能够通过从server上下载更新dex到该路径下就OK了.这样的修复方式因为仅仅是替换了dex文件,没有更新资源文件,所以仅仅能修复一些不牵扯到更改现有资源的紧急bug.相信在大多数情况下也够用了.而且基于Proxy/Delegate也能够非常好得做扩展,比如插件化,多dex技术等.

转载请注明出处:http://blog.csdn.net/l2show/article/details/46967987

posted on 2017-04-17 08:17  ycfenxi  阅读(185)  评论(0编辑  收藏  举报