你真的了解Instant Run吗?

作者: 不二先生的世界 | 来源:发表于2016-05-09 00:53 被阅读974次
Android Studio.png

在Instant Run刚出来的时候,反编译源码写过一篇Instant Run原理解析,但过于基于源码,感觉没有写清楚,这周Android Developers推出了Instant Run: An Android Tool Time Deep Dive来讲解Instant Run原理,既然是官方推出的,当然要重点看看,整理了一下,算是对Instant Run有了更全面的了解。

完整构建和部署

首先我们来看下没有使用Instant Run,代码改变之后的完整构建和部署的流程

完整构建和部署流程.png Android Build Process流程图.png

我们可以看到,在没有Instant Run时,代码变更之后运行,需要构建Application,你的Mainfest文件被合并,和资源文件一起被打包到APK里面,类似的,Java文件被编译成字节码,然后转换成DEX文件,最后部署App,重新启动App,重新启动Activity,最终变更的代码才能变执行。之间需要花费大量的时间,工程小还好,一旦大了就需要花费几分钟甚至几十分钟时间,严重影响了我们开发的效率和心情(最重要的是心情!),还能不能愉快地编程了!Google真是急人之所急,我们的救世主呀,在Android Studio 2.0之后就推出了Instant Run功能,看字面意思就知道是即时运行的意思,本着工程师探索原理的精神,让我们一探究竟。

Instant Run分类

Instant Run .png

我们可以看到,和完整构建、停止、重新安装和加载App相比,Instant Run 只增量构建和部署代码改变的部分,在很大程度上缩短构建和部署的时间。Instant Run有3种交换类型,分别是Hot Swap、Warm Swap和Cold Swap,Instant Run会根据改变代码的类型,自动决定使用哪种类型。

Instant Run如何工作

Instant Run构建

Instant Run构建流程.png

根据上图,我们可以看到Instant Run构建流程,首先增加字节码到你的Class文件,用来让我们之后进行替换,然后增加一个新的App Server Class运行在之后你的App里面,用来传输之后在运行期变化的代码,Gradle也会将修改Mainfest进行合并,让我们运行实时代码的改变。

App Server运行

App Server运行流程.png

当你在Android Studio点击Run按钮时,首先会检测在你的App里是否有一个开启Socket端口的Server在运行,来确定Instant Run是否可用,在发送变化的代码之前它也会检测App构建的ID来确定是期望的版本,当你在开发过程中,Android Studio会监控哪些文件已经被改变,运行一个自定义的Gradle Task为那些改变的class文件创建一个DEX文件,这个新的DEX文件会被Android Studio部署到我们运行的App Server里面,App Server接收到之后就会加载和部署被更新的classes,使用之前注入到我们原始类,委托方法来调用我们刚才加载覆盖的新classes里的方法。

Hot Swap

Hot Swap.png

Hot Swap主要用于改变现有方法的实现代码导致的代码改变,这是最快的一种交换方式,不需要重启App或者Activity,在你下一次调用方法时,新的实现就能被调用。

Warm Swap

Warm Swap.png

Warm Swap主要用于修改或者删除已经存在的资源文件,这个交换仍然非常快,但需要重启Activity,因为加载这些被影响的资源,重启是必须的。虽然改变的所有资源都需要被重新打包,但我们是增量开发,可以只打包和部署已经改变的资源,不过和Mainfest相关的资源改变或者Mainfest自身的改变,Warm Swap不会有任何作用,那是因为从Mainfest里面读取值,在APK被安装的时候就已经被确定下来,所以那些改变就需要重新安装才能看到。从这里我们就能看出来,Instant Run并不支持改变定义App名称的字符串或者App图标。

Cold Swap

Cold Swap.png

Cold Swap支持新增、移除、修改注释、实例或者静态字段,实例或者静态方法签名、改变父类classes或者类静态初始化。这种交换会慢一点,虽然不需要完整构建一个新的APK,但需要重启Application。原理就是发送有效代码的DEX文件到指定设备,通过App加载多个DEX来实现代码的改变,这就需要ART,所以Cold Swap只在Android 5.0及以上的设备才有效,那些Android 5.0以下的设备就需要部署一个完整的APK。

总结

到目前为止,我想大家已经理解了这3种交换类型的原理,也能了解其中的局限性,做到知其然,知其所以然。最后祝大家利用好Instant Run,享受即时编程。

参考资料

官方视频
About Instant Run

可以随意转发,也欢迎关注我的简书,我会坚持给大家带来分享。

相关文章

  • 你真的了解Instant Run吗?

    在Instant Run刚出来的时候,反编译源码写过一篇Instant Run原理解析,但过于基于源码,感觉没有写...

  • 热修复实现原理(三)

    热修复实现原理——instant run 一、Instant Run 简介 Instant Run,是androi...

  • [Android 学习笔记] instant-run 源码学习

    instant-run 源码地址仔细过一遍 README, 对 instant-run 就会有一个大体的了解;in...

  • Android新特性Instant Run详解

    关于 Instant Run Android Studio 2.0 中引入的 Instant Run 是 Run ...

  • InstantRun是如何工作的

    原文地址 Instant Run: How Does it Work?! Instant Run是Android ...

  • Android note 手写热修复

    1.Android studio : 关闭 Instant run Instant run 多次build的apk...

  • Instant Run

    Android开发者,很多的时候我们需要花大量的时间在bulid,运行到真机(虚拟机)上,对于ios上的Playg...

  • Instant Run

    Android Studio 2.0 中引入的可以“大幅减少应用更新时间”的功能。更改代码再次更新应用,Insta...

  • Instant Run

    如何编译运行app 我们要编译运行一个AS工程,只需在AndroidStudio上点击几下按钮就行了。Instan...

  • Instant Run

    Instant Run简介 传统情况:修改程序后重新运行,会经历:代码重新编译 -> 停止App程序 -> 重装新...

网友评论

    本文标题:你真的了解Instant Run吗?

    本文链接:https://www.haomeiwen.com/subject/ddtsrttx.html