當(dāng)前位置:首頁(yè) > 芯聞號(hào) > 充電吧
[導(dǎo)讀]隨著2019華為開(kāi)發(fā)者大會(huì)的臨近,華為消費(fèi)者業(yè)務(wù)CEO余承東此前在P30國(guó)內(nèi)發(fā)布會(huì)上宣布的“能夠?qū)崿F(xiàn)Android性能革命”的方舟編譯器也即將進(jìn)入到開(kāi)源階段。 雖然此前在4月份華為已經(jīng)就方舟編譯器進(jìn)行

隨著2019華為開(kāi)發(fā)者大會(huì)的臨近,華為消費(fèi)者業(yè)務(wù)CEO余承東此前在P30國(guó)內(nèi)發(fā)布會(huì)上宣布的“能夠?qū)崿F(xiàn)Android性能革命”的方舟編譯器也即將進(jìn)入到開(kāi)源階段。

雖然此前在4月份華為已經(jīng)就方舟編譯器進(jìn)行了介紹,但人們更加關(guān)心的是:華為方舟編譯器的革命性到底體現(xiàn)在哪里?

針對(duì)這個(gè)問(wèn)題,余承東在8月6日推薦了一篇由“菊廠(chǎng)搞機(jī)”發(fā)表的一篇題為《華為新貴!方舟編譯器的榮光和使命》的長(zhǎng)文,該文對(duì)華為方舟編譯器的實(shí)現(xiàn)原理和背后故事進(jìn)行了解讀—;—;而雷鋒網(wǎng)也希望由此提取出關(guān)于華為方舟編譯器實(shí)現(xiàn)Android性能革命的諸多要點(diǎn)。

Android代碼編譯的原理和弊端

在目前全世界的多種編程語(yǔ)言中,Android操作系統(tǒng)采用的是Java語(yǔ)言。

Java語(yǔ)言是在1995年5月發(fā)布的,它的一個(gè)重點(diǎn)特點(diǎn)就是可以跨平臺(tái)操作,而且需要借助虛擬機(jī)機(jī)制來(lái)解釋源代碼并調(diào)度硬件資源;但同時(shí)Java是一種預(yù)編譯語(yǔ)言,需要先在開(kāi)發(fā)者環(huán)境中將源代碼(SourceCode)轉(zhuǎn)換成字節(jié)碼(ByteCode),然后在設(shè)備上運(yùn)行時(shí)再將字節(jié)碼編譯或解釋成硬件能聽(tīng)得懂的機(jī)器碼。

也就是說(shuō),從Java的字節(jié)碼到機(jī)器碼,中間需要兩樣?xùn)|西:

1、虛擬機(jī),用來(lái)調(diào)度硬件資源;

2、翻譯器(將Java字節(jié)碼解釋成機(jī)器語(yǔ)言)或者編譯器(將Java字節(jié)碼編譯成機(jī)器碼)。此處要注意的是,翻譯器和編譯器是不同的;編譯器是把源程序的每一條語(yǔ)句都編譯成機(jī)器語(yǔ)言并保存成二進(jìn)制文件,這樣運(yùn)行時(shí)計(jì)算機(jī)可以直接以機(jī)器語(yǔ)言來(lái)運(yùn)行此程序,因而速度很快;而解釋器則是只在執(zhí)行程序時(shí),才一條一條地解釋成機(jī)器語(yǔ)言來(lái)讓計(jì)算機(jī)執(zhí)行,因此運(yùn)行速度不如編譯后的程序運(yùn)行得快。

而對(duì)于Android操作系統(tǒng)來(lái)說(shuō),為了將Java字節(jié)碼變成機(jī)器語(yǔ)言,Google在不同的版本中進(jìn)行了多樣化的嘗試,其目的自然是不斷推動(dòng)應(yīng)用程序的運(yùn)行速度向前發(fā)展;我們來(lái)看一下Android在不同版本是怎么做的:

Android 1.0(2008年):采用一個(gè)名為Dalvik的虛擬機(jī),并且集成了一個(gè)解釋器。當(dāng)App運(yùn)行時(shí),就會(huì)調(diào)用這個(gè)解釋器,對(duì)代碼進(jìn)行逐句解釋?zhuān)俣群苈?/p>

Android 2.2(2010年):引入JIT(Just In Time)即時(shí)編譯機(jī)制,當(dāng)App運(yùn)行時(shí),會(huì)將用戶(hù)經(jīng)常使用的功能編譯為機(jī)器能直接執(zhí)行的010101機(jī)器碼,不用一句一句地去翻譯。當(dāng)出現(xiàn)不常用的功能時(shí),再調(diào)用解釋器來(lái)翻譯;這樣速度加快,但每次啟動(dòng)App都要重新編譯一次,不能一勞永逸。

Android 5.0(2014年10月):將虛擬機(jī)Dalvik換成ART(Android Run Time),將JIT的編譯器替換成AOT(Ahead of Time)。如此,App在下載后安裝到手機(jī)上時(shí)同時(shí)把能編譯的代碼先編譯成機(jī)器聽(tīng)得懂的101010;剩下不太好翻譯的代碼,就在用戶(hù)使用時(shí)再叫醒解釋器來(lái)翻譯。如此,不用每次打開(kāi)App都需要編譯,但安裝App的時(shí)間有點(diǎn)長(zhǎng),而且占用手機(jī)空間。

Android 7.0(2017年):采用混合編譯機(jī)制,安裝時(shí)先不編譯中間代碼,而是在用戶(hù)空閑時(shí)將能夠編譯成機(jī)器碼的那部分代碼,通過(guò)AOT編譯器先靜態(tài)編譯了。如果AOT還沒(méi)來(lái)得及編譯或者不能編譯,再調(diào)用JIT+解釋器。這種機(jī)制,相當(dāng)于用時(shí)間換空間,既縮短了用戶(hù)安裝APP的等待時(shí)間,又將虛擬機(jī)里編譯器和解釋器能做的優(yōu)化提升到最大效率了。

可以看到,無(wú)論是編譯器還是解釋器,只是在虛擬機(jī)上打補(bǔ)丁,手機(jī)上的虛擬機(jī)+編譯器+解釋器本身不僅占用硬件資源,還無(wú)法最大發(fā)揮軟件運(yùn)行性能。正因如此,所以絕大部分手機(jī)廠(chǎng)商只能無(wú)奈的通過(guò)簡(jiǎn)單粗暴提升Android手機(jī)的內(nèi)存和存儲(chǔ)空間,來(lái)彌補(bǔ)虛擬機(jī)的弊端。

由此出發(fā),Android系統(tǒng)在性能和應(yīng)用運(yùn)行層面有四個(gè)方面的問(wèn)題:

1、如前所述,離不開(kāi)虛擬機(jī);

2、為了與C/C++等代碼進(jìn)行交互,Java原生接口(Java Native Interface,簡(jiǎn)稱(chēng)JNI)應(yīng)運(yùn)而生。目前95%的TOP應(yīng)用都是使用Java和C/C++等多種語(yǔ)言混合開(kāi)發(fā)而成。Java和C/C++屬于兩種不同架構(gòu)的語(yǔ)言,各有自己的使用規(guī)范。為了APP正常運(yùn)行,它倆之間需要互通有無(wú),這個(gè)互通有無(wú)的接口就是JNI。在數(shù)據(jù)訪(fǎng)問(wèn)、函數(shù)調(diào)用、生命周期維護(hù)、異常處理等方面都需要這兩種代碼互相調(diào)用。這就意味著手機(jī)硬件資源要分配一部分給JNI去做調(diào)度—;—;這一機(jī)制本身的效率就不高,而且占用了硬件資源。

3、Android虛擬機(jī)的編譯器受限于手機(jī)硬件和代碼優(yōu)化模板單一,代碼優(yōu)化空間有限。編譯器包含三個(gè)部分:前端FrontEnd,主要負(fù)責(zé)將源代碼翻譯成IR(Intermediate Representation);中端的Optimizer主要負(fù)責(zé)代碼優(yōu)化,將前端翻譯過(guò)來(lái)的IR代碼優(yōu)化得更高效;后端BackEnd則將優(yōu)化后的IR編譯成101010的機(jī)器碼—;—;為了防止生態(tài)過(guò)于碎片化,Android只為第三方開(kāi)放了簡(jiǎn)單的編譯代碼優(yōu)化模板,代碼優(yōu)化空間有限。

4、Java現(xiàn)有的內(nèi)存回收機(jī)制容易造成“間歇性”卡頓。當(dāng)手機(jī)內(nèi)存資源不夠用的時(shí)候,Android虛擬機(jī)就會(huì)召喚GC(Garbage Collection,垃圾回收)讓所有手機(jī)運(yùn)行的Java線(xiàn)程全部暫停,等待它回收內(nèi)存空間,避免過(guò)載超載。這個(gè)GC機(jī)制,無(wú)法精確控制和干預(yù),用戶(hù)也無(wú)法把它去掉,所以性能比較差的手機(jī)還存在“間歇性”卡頓。

這四個(gè)問(wèn)題,也是華為試圖通過(guò)方舟編譯器解決的問(wèn)題。

華為方舟編譯器是如何解決問(wèn)題的?

在回答這個(gè)問(wèn)題之前,先看一下華為從事方舟編譯器工作的時(shí)間線(xiàn):

2009年,華為啟動(dòng)5G基礎(chǔ)技術(shù)研究的同時(shí),開(kāi)始創(chuàng)建編譯組,第一批海內(nèi)外研究人員加入。

2013年,華為推出面向基站領(lǐng)域的自研編譯器HCC,并正式提出編譯器框架構(gòu)想。

2014年,眾多海內(nèi)外專(zhuān)家加入華為,方舟項(xiàng)目正式啟動(dòng)。

2016年,成立編譯器與編程語(yǔ)言實(shí)驗(yàn)室。

2017年,方舟編譯器上的第一個(gè)Java程序“HelloWorld”跑通。

2018年春節(jié)前一周,方舟編譯器跑通Android系統(tǒng)所有后臺(tái)服務(wù),并成功移植到手機(jī)。

2019年4月,華為方舟編譯器在P30系列的國(guó)內(nèi)發(fā)布會(huì)上對(duì)外宣布。

那么,方舟編譯器的原理究竟是如何實(shí)現(xiàn)的?

實(shí)際上,華為所謂的“方舟編譯器”與其說(shuō)是一個(gè)編譯器,不如說(shuō)是一個(gè)編譯運(yùn)行系統(tǒng);這個(gè)系統(tǒng)的運(yùn)行需要開(kāi)發(fā)環(huán)境和終端(也就是智能手機(jī))的配合,其目的是繞過(guò)Android操作系統(tǒng)中App的運(yùn)行所必須依賴(lài)的虛擬機(jī),將Java/C/C++等混合代碼一次編譯成機(jī)器碼直接在手機(jī)上運(yùn)行,徹底告別Java的JNI額外開(kāi)銷(xiāo),也徹底告別了虛擬機(jī)的GC內(nèi)存回收帶來(lái)的應(yīng)用進(jìn)程掉線(xiàn)—;—;從而最終實(shí)現(xiàn)Android操作系統(tǒng)的流暢度。

正如上文所言,在方舟編譯器的這一實(shí)現(xiàn)過(guò)程中,需要解決四個(gè)方面的問(wèn)題。

第一:將Java代碼直接編譯成機(jī)器碼

就目前的情況來(lái)看,Java編譯成機(jī)器碼的過(guò)程中,要面臨的難題是Java中的動(dòng)態(tài)語(yǔ)義(與之對(duì)應(yīng)的是靜態(tài)語(yǔ)義,它是通過(guò)提前翻譯能夠解決的),靜態(tài)語(yǔ)義指的是確定的語(yǔ)言和意思,而動(dòng)態(tài)語(yǔ)義指的是需要結(jié)合上下文來(lái)理解的內(nèi)容—;—;這其中,如果要像編譯靜態(tài)語(yǔ)義一樣去編譯動(dòng)態(tài)語(yǔ)義,很多知乎大神認(rèn)為是根本就不可能的。

而這個(gè)不可能,正是華為在開(kāi)發(fā)方舟編譯器過(guò)程中解決的問(wèn)題。

具體來(lái)說(shuō),方舟編譯器通過(guò)編譯階段和運(yùn)行階段的雙向加持,將靜態(tài)編譯動(dòng)態(tài)語(yǔ)義最大的兩大難點(diǎn)解決:一是設(shè)計(jì)數(shù)據(jù)模型,二是如何在運(yùn)行時(shí)高效獲得動(dòng)態(tài)信息。

方舟編譯器團(tuán)隊(duì)基本遍歷了Java的動(dòng)態(tài)語(yǔ)義,進(jìn)行了大規(guī)模的數(shù)據(jù)建模。同時(shí),大大提高了編譯時(shí)動(dòng)態(tài)語(yǔ)義分析的精度,特別是涉及跨語(yǔ)言調(diào)用時(shí);另外,華為設(shè)計(jì)了一套具有核心專(zhuān)利的動(dòng)態(tài)語(yǔ)義匹配機(jī)制,有效降低了運(yùn)行時(shí)動(dòng)態(tài)語(yǔ)義的開(kāi)銷(xiāo)。

由此,方舟編譯器能夠?qū)ava代碼編譯成機(jī)器能直接執(zhí)行的語(yǔ)言。華為方面表示,經(jīng)過(guò)華為方舟編譯器的App,再也不需要在手機(jī)上編譯了,徹底告別了虛擬機(jī),從而帶來(lái)了媲美甚至超越iOS的Android體驗(yàn)。

第二:解決混合語(yǔ)言的JNI開(kāi)銷(xiāo)

由于95%的Top應(yīng)用都是Java/C/C++等混合語(yǔ)言編寫(xiě)而成;因此方舟編譯器還需要干掉混合語(yǔ)言互相調(diào)用帶來(lái)的JNI開(kāi)銷(xiāo)。

這里就涉及到上文提到的一個(gè)名詞IR,它是用來(lái)表示代碼的數(shù)據(jù)結(jié)構(gòu),它是編譯器的各模塊以及相關(guān)工具之間用來(lái)傳遞信息的“協(xié)議和通用語(yǔ)言”,也是程序變換和編譯優(yōu)化各種算法的承載體。它是編譯器的“大腦”,直接決定了編譯器的最終效果—;—;因此,它的難度是最高的。

華為方舟編譯器團(tuán)隊(duì)對(duì)IR進(jìn)行了長(zhǎng)達(dá)五年的精雕細(xì)琢,逐漸摸索出“大腦”里每一條神經(jīng)、每一個(gè)神經(jīng)元的信號(hào)規(guī)律,并在此基礎(chǔ)上發(fā)明了一套核心專(zhuān)利,使得不同語(yǔ)言代碼在開(kāi)發(fā)者環(huán)境中能夠統(tǒng)一編譯成同一套可直接執(zhí)行的機(jī)器碼,從而徹底消除了混合語(yǔ)言互相調(diào)用的開(kāi)銷(xiāo)。

也就是說(shuō)華為方舟編譯器可以將混合語(yǔ)言實(shí)現(xiàn)統(tǒng)一的中間表示IR,這就相當(dāng)于同一個(gè)人能夠理解全世界的語(yǔ)言—;—;當(dāng)然,這背后是華為方舟編譯器團(tuán)隊(duì)基于多個(gè)編程語(yǔ)言的深刻理解和大量研發(fā)積累。

第三:在統(tǒng)一IR之外進(jìn)行代碼優(yōu)化

華為方舟編譯器,直接將代碼優(yōu)化從手機(jī)環(huán)節(jié)搬到了開(kāi)發(fā)者環(huán)境,未來(lái)還可能搬到云端。利用開(kāi)發(fā)者環(huán)境更強(qiáng)大的算力,可以實(shí)現(xiàn)更先進(jìn)和精細(xì)的優(yōu)化算法,來(lái)達(dá)到更佳的優(yōu)化效果—;—;華為表示,在很多特定場(chǎng)景代碼優(yōu)化的提升甚至是顛覆性的。

值得一提的是,開(kāi)發(fā)者使用方舟編譯器,并不需要改變?cè)瓉?lái)的編碼習(xí)慣。開(kāi)發(fā)者可以自行開(kāi)發(fā)代碼優(yōu)化算法,也可以?xún)H通過(guò)方舟編譯器預(yù)置的算法進(jìn)行代碼優(yōu)化。未來(lái),華為還將提供代碼調(diào)優(yōu)工具,開(kāi)發(fā)者可以選擇根據(jù)工具的優(yōu)化建議來(lái)調(diào)整代碼,和方舟編譯器配合獲得更優(yōu)的執(zhí)行效果。

第四:解決Android內(nèi)存回收帶來(lái)的卡頓問(wèn)題

為了解決這個(gè)問(wèn)題,方舟編譯器采用了引用計(jì)數(shù)法(RC,Reference Counting)來(lái)進(jìn)行內(nèi)存的實(shí)時(shí)回收,并且配合使用了專(zhuān)門(mén)的消除環(huán)算法(消除對(duì)象互相引用帶來(lái)的無(wú)法回收問(wèn)題),來(lái)避免GC集中式回收帶來(lái)的系統(tǒng)卡頓。相比GC,方舟的內(nèi)存回收是實(shí)時(shí)的而非集中式的,且不需要暫停應(yīng)用進(jìn)程,這樣便大大消除了卡頓。

另外,軟件有一個(gè)大家都很熟悉的死循環(huán),就是電腦被一個(gè)無(wú)限循環(huán)的運(yùn)行程序把計(jì)算機(jī)資源占光。這種“死循環(huán)”在軟件中叫“環(huán)引用”。為了從機(jī)制避免手機(jī)內(nèi)存被環(huán)引用“吃掉”,方舟編譯器引入annotation的“告警”標(biāo)示,對(duì)基礎(chǔ)類(lèi)的環(huán)進(jìn)行標(biāo)注。

當(dāng)然,Java程序員也可以對(duì)業(yè)務(wù)代碼中的環(huán)進(jìn)行標(biāo)注。經(jīng)過(guò)豐富的實(shí)踐驗(yàn)證,方舟這種機(jī)制可以減少大部分程序中環(huán)的出現(xiàn)。另外一方面,方舟編譯器在運(yùn)行狀態(tài)下引入了高效的環(huán)回收機(jī)制,允許有選擇的智能回收某個(gè)APP的內(nèi)存占用,這對(duì)傳統(tǒng)的環(huán)回收算法是一個(gè)改進(jìn)。

總結(jié)來(lái)看,面對(duì)現(xiàn)有的Android系統(tǒng)在代碼編譯、運(yùn)行、IR、內(nèi)存回收等四個(gè)層面的問(wèn)題,華為方舟編譯器分別給出了自己的解決方案,這其中的核心創(chuàng)新點(diǎn)是混合語(yǔ)言的統(tǒng)一中間表示和完全靜態(tài)編譯,但更重要的是華為在解決Android操作系統(tǒng)App運(yùn)行問(wèn)題的嶄新思路,以及為了實(shí)現(xiàn)這種思路而敢于大力投入的勇氣。

總結(jié)

方舟本質(zhì)上不僅僅是一個(gè)編譯器,而是一個(gè)編譯系統(tǒng),它需要通過(guò)用戶(hù)終端和開(kāi)發(fā)者的共同支持。

對(duì)于華為手機(jī)用戶(hù)來(lái)說(shuō),華為在手機(jī)終端中已經(jīng)用方舟編譯器替代了Android system-server的所有后臺(tái)服務(wù),這一項(xiàng)就已經(jīng)足夠讓華為EMUI比其他Android系統(tǒng)更快一步—;—;根據(jù)華為官方測(cè)試,方舟編譯器提升手機(jī)系統(tǒng)操作流暢度高達(dá)24%,系統(tǒng)響應(yīng)性能提升44%。

當(dāng)然,華為要想充分發(fā)揮方舟這個(gè)編譯系統(tǒng)的實(shí)力,還離不開(kāi)開(kāi)發(fā)者在開(kāi)發(fā)層面對(duì)方舟編譯器的大力支持,這本質(zhì)上是華為在現(xiàn)有Android開(kāi)發(fā)生態(tài)之外另辟蹊徑打造的一個(gè)全新開(kāi)發(fā)環(huán)境—;—;它究竟能否得到開(kāi)發(fā)者的支持,還需要等華為將其開(kāi)源之后才能有答案。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專(zhuān)欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車(chē)的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車(chē)技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車(chē)工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車(chē)。 SODA V工具的開(kāi)發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車(chē) 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶(hù)希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開(kāi)幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱(chēng),數(shù)字世界的話(huà)語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱(chēng)"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉