京东6.18大促主会场领京享红包更优惠

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 7888|回复: 0

华为的方舟编译器如何革命?脱离安卓后会不会用在鸿蒙上

[复制链接]

14

主题

0

回帖

10

积分

新手上路

积分
10
发表于 2019-5-28 09:47:36 | 显示全部楼层 |阅读模式 来自 中国
在上海的华为新品发布会上,除了可以拍月亮的华为 P30 系列,余承东还亲自抛出了两项软件层面的“重磅炸弹”,分别是方舟编译器和 EROFS 超级文件系统;其中,华为方舟编译器可以实现“架构级优化和显著提升性能”,可以解决安卓程序“边解释边执行”的问题,从而被余承东称之为 “安卓性能革命”。5 A* Q# D; u& \% j! d4 M

1 ~' a  F' D3 U! e4 _; v 发布会结束之后,华为方舟编译器引起了外界的热议。
( l0 t, |/ N( M- k/ n7 P1 \) { 那么,方舟编译器究竟是什么?它的 “革命性” 到底体现在哪里?面对这些问题,华为终于在两周之后举行了媒体沙龙,对方舟编译器进行了更加细致的解读。! P9 W8 }% ?# V* b1 J8 u! {# ^
Android 生态中编译器的工作原理
. U( `: r% K$ c! M0 t/ |1 o0 I) f 在了解方舟编译器之前,我们必须得首先了解 Android 操作系统中的编译器的运行机制。
' k1 E* }: S  y/ b 从 VirtualXposed/处了解到,当前 Android 平台的绝大多数应用是使用 Java 语言写的,CPU 只能理解汇编指令,无法直接识别 Java 语言的虚拟机指令;为了让 CPU 能运行 Java 语言编写的程序,一般有两种办法:
! ^/ l4 E; b/ `+ y4 p* i* u" p+ K: ~ 引入一个中间层,这个中间层负责 Java 代码的执行,然后这个中间层本身编译为 CPU 能理解的汇编指令,也就是 CPU -> 中间层 -> Java 代码。如果这个中间层采用 Java 语言直接作为输入,理解一句 Java 语句就把Java语言翻译一下让 CPU 执行一段,我们一般称这种模式为「解释执行」。毋庸置疑这种方式效率是相当低效的。直接把 Java 语言翻译成 CPU 能理解的机器语言。这里又有两种方式:第一,在程序运行之前直接把 Java 代码编译为机器语言。这种模式称之为 AOT(Ahead of time)编译;第二,在程序运行起来之后,实时地把 Java 语言编译为机器语言然后执行。这种模式称之为 JIT(Just in time) 编译。具体在 Android 平台上,代码编译经历了数个阶段。5 J  M2 M( u7 `' T
在 Android 5.0 正式采用 ART 之前8 Y3 {  T! H( _& ~3 v0 G, M+ N9 h+ p' L
,Android 采用的是解释执行 + JIT 的方式执行 Java 代码。在这个阶段是货真价实的「边解释边执行」的模式,代码效率相当低下,再加上那时候同样表现不行的 GC(垃圾回收),Android 非常难用。
2 u% P9 _; R; ?4 b% }+ d 在 Android 5.0 至 Android 6.0 阶段
# V" G/ R6 U& q ,Google 推出了 ART(Android Runtime)来解决之前的 Java 代码执行效率问题。这个阶段采用的是完全 AOT 模式;Android 应用在安装的时候,系统会把所有Java代码提前编译为机器码。这种模式有两个缺点:6 T0 }. Q9 c- }
安装速度巨慢。即使是高通骁龙 855 采用 AOT 模式编译一下安装包比较大的应用(如支付宝)可能就要一分钟。
- t/ [; A7 x/ r 而那个时候的 CPU 并不如现在,安装一个应用需要很长时间。更要命的是,系统 OTA 开机会对所有的应用执行 AOT 操作,这时候开机速度可能需要很长时间。
" {$ a- J# c$ @* ^3 _1 i2 [9 A 占用磁盘空间,Java 代码编译为机器码之后体积会急剧膨胀。到了 Android 7.0,Google 做了很大的改进;这一改进是基于这样一个事实:我们使用一个应用的时候,基本每个人只使用它一小部分功能,为什么要把所有代码全编译呢?因此只编译用户经常用的那部分代码就 OK 了,这样安装的时候速度比较快,等用户启动的时候系统就能知道哪部分代码经常被执行,把这部分代码编译为机器码,运行起来速度也快。
5 e1 b; C/ I, C6 s* E0 i 于是 Google 又引入了 JIT,这时候的执行模式是 AOT + JIT + 解释执行。具体来看:' B  S1 B/ ?( V$ u9 Y
应用安装的时候不执行 AOT 编译,安装速度飞快。初次使用应用的时候没有机器码,因此只能解释执行。应用运行起来之后,系统收集经常被运行的代码的信息,做两件事:1)在必要的时候在运行时直接把 Java 代码编译为机器码 (JIT),然后使用机器码执行提高运行效率。2)把这个「经常被运行的代码信息保存起来」。设备空闲的时候,系统拿出应用运行时候保存的「热点代码信息」直接把这些代码编译为机器码 (AOT)。Android 8.0 上改进了解释器,解释模式执行效率大幅提升;Android 10.0 上提供了预先放置热点代码的方式,应用在安装的时候就能知道常用代码会被提前编译。可以看到,当前 Android 平台的执行模式在空间占用+安装速度+运行速度上已经达到了一个很好的平衡。
+ S( i$ ^) c9 \ 总结来看,目前的 Android 采用的是解释执行 + 还算可以的 JIT + AOT 的综合模式;但并没有摆脱这样一个前提,即应用在被打包成 APK 的时候,采用的还是 Java 代码。换句话说,在 APK 变成用户可应用的过程中,还经历了一个在 Android 系统内部的编译过程,这是一个绕不过的坎。0 ?. n- J6 K: w. i& B
* q3 \: {8 x7 i$ t4 o$ B8 b8 t1 `
按照华为方面在媒体沙龙中的解读,这个在现有 Android 中绕不过去的坎,被称为虚拟机(Virtual Machine,简称 VM),它包含翻译器和编译器,其目的就是把 Java 高级语言转换成机器能懂的语言——这一转换过程导致卡顿,并且 VM 的统一回收内存垃圾额也会带来卡顿。
2 r  W8 F: d7 {2 J8 f6 M 华为方舟编译器究竟改变了什么?
- v  K& P1 j" }3 k# p+ W/ ^) C3 f 首先,方舟编译器是配合华为 EMUI 9.1 操作系统而打造的一个编译工具。
* ]! Y  S: {6 ] 按照华为方面的说法,虽然方舟编译器是在 2019 年 4 月 11 日发布,但是华为早在 5 年前就开始布局,2013 年推出了自研编译器 HCC,2014 年编程大神 Fred Chow 加入,担任华为编译器技术首席科学家,2016 年华为成立编译器与编程语言实验室,投入了数百的专家团队经历了多次尝试,才在 EMUI 9.1 上实现了机器代码的翻译。  x5 {2 m6 c5 p, w+ ^4 M# O

2 D7 O! a0 f/ o% t4 G 按照上述 Android 操作系统的代码运行逻辑,华为编译器最大的优势在于,它绕过了 VM。: E' g" J5 J, ^$ P1 K& a
简单来说,在百人专家团队的打造下,华为方舟编译器可以将高级语言(Java)直接变成机器码,无需再通过 Android 操作系统中内置的 VM 编译器。按照华为方面的说法:方舟编译器编译的应用在开发阶段就已完成;也就是说,只要是经过编译器编译的应用,在应用市场上上架了以后,用户下载 APK 的就是编译过的了。
% b: J) P7 q+ p9 t8 `9 A9 x5 ?

  [# ?  r' m- U 换句话说,通过方舟编译器,开发者的应用在下载之前就已经转化成为机器可以识别的代码,因而可以在手机上快速安装、启动和运行,而无需在经过 VM 的编译——某种程度上,方舟编译器是将编译过程提前到应用开发阶段,从而大幅度减少了智能手机和操作系统的运行负担。! \$ X% L* F( O4 g7 z& [2 C" C
按照华为方面的说法,采用华为编译器之后,提升效果如下:
& d, A6 ?. z* r9 |% y EMUI 9.1 仅仅对系统组件 System Server 应用了方舟编译器之后,系统流畅速度提升了 24%,系统响应速度提升了 44%;第三方应用(目前采用了新浪微博极速版)的操作流畅度提升了 60%。不可忽视的是,实际上,要想实现华为所言的效果,就首先需要第三方的应用开发者采用方舟编译器对自家的 App 提前进行改造,从而能够上架华为应用商店——这也是余承东在 4 月 11 日的发布会呼吁开发者积极参与的原因。! e$ n% }  M  j) i& c% t
除了代码编译,方舟编译器也提供了更高效的内存机制,它与 Android 内存回收的不同之处在于:' ^8 j3 G0 u6 B  l% J8 n
内存管理是程序开发与运行时需要重点考虑的部分,也和系统流畅度息息相关。Android 在内存回收上采用集中回收机制,发声全局回收时更需要暂停应用,这也是随机卡顿的根因之一。而方舟编译器提供了更高效的内存回收机制,回收时无需暂停应用,随时用随时回收,大大提高运行速度。
. C, u2 V5 Q2 J

! p6 X8 O( H" u' Q  \2 R. N4 T. I 另外,在方舟编译器的编译环境下, 还可以对代码进行优化。目前,由于 Android ART 的 AoT 和 JIT 动态编译因为是运行在手机上,受资源所限,因而只能使用简单的优化算法。而方舟编译器由于是在应用开发阶段进行编译,所以可以允许不同应用灵活采用不同的编译优化方案,而且因为在开发环境编译不会受到手机性能的限制,可以使用更多先进的优化算法,从而使得每个应用的性能达到最佳。
0 T. X+ ^8 C2 a (文章内容来源网络,如有侵权请联系我们)
8 O# v* z0 m+ C. g2 K
3 k- c9 L: B" W3 f* F: U. c% i$ Q1 j
$ r) ]) C* [7 I
  g0 o; e0 D0 |7 v. U来源:http://www.yidianzixun.com/article/0M6pEfDE% E) \7 U1 s. D6 E1 t7 ~
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

×

帖子地址: 

梦想之都-俊月星空 优酷自频道欢迎您 http://i.youku.com/zhaojun917
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

站长推荐上一条 /6 下一条

QQ|手机版|小黑屋|梦想之都-俊月星空 ( 粤ICP备18056059号 )|网站地图

GMT+8, 2025-7-18 12:55 , Processed in 0.039066 second(s), 24 queries .

Powered by Mxzdjyxk! X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表