在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

HDC技術分論壇之ArkCompiler原理解析

HarmonyOS開發(fā)者 ? 來源:HarmonyOS開發(fā)者 ? 作者:xianyuqiang ? 2021-10-29 10:32 ? 次閱讀

作者:xianyuqiang 編譯器首席架構師

ArkCompiler(方舟編譯器)是組件化、可配置的多語言編譯和運行平臺,它既能支撐單一語言運行環(huán)境,也能支撐多種語言組合的運行環(huán)境。它目前主要支持的語言是JavaScript、TypeScript和Java。

一、概述

HarmonyOS的設計目標,是成為打通手機、PC、平板、電視、車機和智能穿戴等多種設備的統(tǒng)一操作系統(tǒng)

其應用開發(fā)有多編程語言、多范式的支持需求,其中高級編程語言包括JavaScript、TypeScript、Java等,開發(fā)范式包括聲明式UI范式、分布式編程范式。我們需要相應的編譯器和運行時來支撐這些高級應用編程語言的高效開發(fā)、部署和運行。使應用開發(fā)者能使用同一套開發(fā)框架實現(xiàn)一次開發(fā)多端部署運行。并且讓使用HarmonyOS設備的用戶,能獲得統(tǒng)一的用戶體驗。于是,ArkCompiler應運而生。

1. 目標

ArkCompiler是為支持多種編程語言、多種芯片平臺的聯(lián)合編譯、運行而設計的統(tǒng)一編程平臺,其設計目標是提供一個語言可插拔、組件可配置的多語言編譯器運行時。

語言可插拔:設計架構上支持多種語言接入,ArkCompiler有能力提供具有高效執(zhí)行性能且具有跨語言優(yōu)勢的多語言運行時,也可以在小設備上提供高效輕量的單一語言運行時。

組件可配置:ArkCompiler具有豐富的編譯器運行時組件系統(tǒng)。通過定制化配置編譯運行時的語言和組件,以支持手機、PC、平板、電視、汽車和智能穿戴等多種設備上不同的性能和內存需求。

2. 架構

如圖2所示,ArkCompiler包含編譯器、工具鏈、運行時等關鍵部件。ArkCompiler工具鏈實現(xiàn)對應語言的前端編譯器,將前端開發(fā)框架的高級語言編譯成統(tǒng)一的字節(jié)碼/二進制文件。根據(jù)不同的應用場景,通過ArkCompiler運行時解釋器解釋執(zhí)行字節(jié)碼文件或JIT/AOT編譯器編譯執(zhí)行對應體系架構的優(yōu)化機器碼,從而提升運行效率和啟動性能。

0a082d6c-385b-11ec-82a8-dac502259ad0.png

圖2 ArkCompiler運行原理

下面,本文將從前端編譯器,運行時展開介紹。

二、前端編譯器

前端編譯器是高級語言通往語言運行時的橋梁,它按照語言規(guī)范,將編程語言表達的語義翻譯為運行時能夠理解的介質,在ArkCompiler解決方案里,這體現(xiàn)為ArkCompiler字節(jié)碼。即圖3中的ArkCompiler Bytecode(簡稱abc)。部分語言,也支持通過ArkCompiler的AOT Compiler組件直接將字節(jié)碼編譯成對應體系架構的優(yōu)化機器碼。

圖3 ArkCompiler前端

1. 前端編譯器功能

在需要支持多種語言的ArkCompiler中,前端編譯器的主要作用是在Host側把源碼生成字節(jié)碼文件,這樣的優(yōu)點:

利用Host強大的計算能力,能夠在運行前做更多更復雜的算法優(yōu)化,減少運行時的工作,提高運行效率。

相比常見的JavaScript運行時,可以把端側的編譯解析過程提前到發(fā)布前,提升程序的啟動性能。

編譯優(yōu)化

ArkCompiler提供對TypeScript(TS)的原生支持。在前端編譯TS源碼時,會利用TS的顯式類型聲明,應用類型推導進行類型優(yōu)化,并且將推導出的類型信息通過字節(jié)碼文件保留至運行時,由此運行時可以直接利用類型信息執(zhí)行快速路徑。

此外,靜態(tài)的類型分析和推導也使得TS AOT (Ahead of Time) Compiler成為可能,靜態(tài)分析得到的類型信息幫助AOT Compiler直接編譯生成高質量的機器碼,使得TS源碼可以直接以機器碼形式運行,進一步提升運行性能。

0b595df8-385b-11ec-82a8-dac502259ad0.png

圖5 編譯優(yōu)化

2. ArkCompiler字節(jié)碼

ArkCompiler字節(jié)碼(ArkCompiler Bytecode)是運行時解釋器能夠解析運行的一種硬件和平臺無關的中間表現(xiàn)形式,以緊湊、可擴展、多語言支持作為設計目標。屏蔽設備的差異,支持應用的跨設備分發(fā)、部署和運行。ArkCompiler采用的是基于寄存器的字節(jié)碼格式。每個寄存器的寬度為64位,最多支持65536個寄存器。

(1)寄存器

ArkCompiler寄存器要求能夠放置對象引用和基本類型,寬度采用64位。寄存器的作用域是以函數(shù)棧幀為范圍。在字節(jié)碼指令編碼中,寄存器索引支持4位、8位以及16位的變長編碼,在支持方法內不同數(shù)量范圍的寄存器尋址的同時減小字節(jié)碼尺寸。

(2)累加寄存器

累加寄存器,俗稱累加器,是一個特殊的寄存器,被指令隱含使用。使用累加器的主要目的是在不損失性能的前提下改善指令編碼密度。在ArkCompiler字節(jié)碼中,上一條指令利用累加器作為結果輸出,下一條指令將此累加器作為輸入,可以有效改善指令密度,減小字節(jié)碼的尺寸。同時,通過在生成字節(jié)碼階段的數(shù)據(jù)流及控制流分析和優(yōu)化,前端編譯器可以有效消除冗余的累加器load和store操作。

(3)基本類型支持

ArkCompiler字節(jié)碼提供對32位(i32)和64位(i64)整型數(shù)值的寄存器操作支持,8位和16位數(shù)值通過擴展到32位來模擬。支持對IEEE-754雙精度浮點f64值的寄存器的操作,f32數(shù)據(jù)類型(IEEE-754單精度)也通過轉換為f64值進行模擬。基本數(shù)據(jù)類型不需要虛擬機進行記錄、跟蹤和推導,而是通過操作不同基本數(shù)據(jù)類型的專用字節(jié)碼進行表示,包括整數(shù)值的符號性。為了更有效地利用字節(jié)碼的指令空間,設計中對高頻使用的數(shù)據(jù)類型和操作引入更多的專用字節(jié)碼,而對低頻使用的數(shù)據(jù)類型和操作采用更通用的字節(jié)碼。

(4)語言相關類型支持

ArkCompiler根據(jù)其執(zhí)行的語言支持層次化的類型系統(tǒng)。這樣,創(chuàng)建或者從常量池加載的字符串、數(shù)組、異常對象等,都是含有相應層次關系的、和具體語言規(guī)范相匹配的數(shù)據(jù)對象。

(5)動態(tài)類型語言支持

為支持類似JS/TS的動態(tài)類型語言,ArkCompiler通過特殊的標記值(“Any”)表示動態(tài)類型值,其包裝了值本身和相應的類型信息(包括基本類型和對象引用類型數(shù)據(jù))。虛擬寄存器的寬度可以容納“Any”值。同時,在動態(tài)類型語言代碼的執(zhí)行上下文中,也可能使用到包含類型檢查指令在內的靜態(tài)確定類型指令序列,以表示動態(tài)類型相關語義。

三、ArkCompiler運行時

ArkCompiler運行時,如圖6所示,被分為了核心運行時(Core Runtime)和各自語言獨立的運行時插件(Runtime Plugin)。

核心運行時主要由運行時的公共核心組件構成,包含定義字節(jié)碼格式和行為的Public ISA模塊,對接系統(tǒng)調用的ArkCompiler Base Platform模塊, 支持Debugger、Profiler等工具的Common Tool模塊和承載字節(jié)碼文件處理的ArkCompiler File模塊等。也提供了可選的語言無關的解釋器、內存管理、編譯器和并發(fā)等基礎設施組件。

各語言運行時插件則包含各語言特有的特性實現(xiàn)以及標準庫來支撐語言的運行行為符合對應的語言規(guī)范,由各語言按需定制。

1. 執(zhí)行引擎

ArkCompiler運行時執(zhí)行引擎有多種組件,包括解釋器、JIT編譯器和AOT編譯器,如圖7所示。

0c264570-385b-11ec-82a8-dac502259ad0.png

圖7 執(zhí)行引擎結構

(1)解釋器

解釋器可直接運行前端編譯器輸出的字節(jié)碼。

(2)JIT Compiler

JIT編譯器一般需要運行時執(zhí)行代碼一段時間,Profiler生成了profiling數(shù)據(jù)之后,根據(jù)profiling數(shù)據(jù)即時編譯生成高質量的機器碼(上圖Optimized Code II)來運行。(JIT可以根據(jù)代碼執(zhí)行情況實時編譯生成最優(yōu)機器指令)

(3)AOT Compiler

AOT編譯器則是在運行前根據(jù)靜態(tài)信息直接編譯生成高質量的目標機器碼(上圖Optimized Code I)在設備上運行,PGO(Profile Guided Optimization)配置文件可以作為AOT Compiler的輸入之一,給AOT Compiler一些指示,比如編譯的范圍以及編譯某個方法時使用哪些優(yōu)化技術。通常這種PGO配置文件由在同等規(guī)格的設備上經過運行時profiling或者大數(shù)據(jù)分析生成。

無論是JIT 編譯器生成的優(yōu)化代碼,還是AOT編譯器生成的優(yōu)化代碼,通常都是在一定優(yōu)化假設或者優(yōu)化推斷的前提下生成的。如果這個前提在運行時不成立,則需要進行Deopt(逆優(yōu)化),回退到解釋器執(zhí)行,這種情況一般較少發(fā)生。

2. 定制化需求

ArkCompiler運行時通過不同執(zhí)行模式的按需組合,支持多種設備不同的定制化需求。

在低端IOT設備上,ArkCompiler執(zhí)行引擎支持純解釋器的執(zhí)行模式,以滿足小設備的內存限制條件;

在高端設備上,ArkCompiler執(zhí)行引擎支持解釋器配合AOT編譯器以及JIT編譯器的模式運行,對相當部分代碼使用AOT編譯器編譯,使得程序一開始就可以運行在高質量的優(yōu)化代碼上,獲得最好的執(zhí)行性能;

在其它設備上,則根據(jù)設備的硬件條件限制來選擇策略,設定高頻使用需要AOT編譯的代碼范圍,其它代碼則依靠解釋器配合JIT Compiler運行,使得應用執(zhí)行性能能夠得到最大化。

為了提升解釋執(zhí)行性能,在特定的體系架構下,解釋器約定了將解釋執(zhí)行上下文中某些頻繁使用的數(shù)據(jù)放在對應的物理寄存器中,比如在Arm64架構下,上下文中當前字節(jié)碼指令地址、累加器值、解釋器棧幀、指令映射表、當前線程對象等,直接放在固定的寄存器上,避免了在棧上頻繁的加載和寫入操作。

3. 并發(fā)

復雜移動應用的開發(fā)和運行對并發(fā)有較強的需求。ArkCompiler運行時除了提供標準的“Java多線程編程”和“運行支持”之外,也提供響應式的Actor并發(fā)編程模型支持。此模型下執(zhí)行體之間不共享任何數(shù)據(jù),通過消息機制進行通信。當前,業(yè)界的一些Actor并發(fā)模型,例如傳統(tǒng)JS引擎的web-worker實現(xiàn),有啟動速度慢、內存占用高等缺陷。

為了利用設備的多核能力獲得更好的性能提升,在Actor內存隔離模型的基礎上,ArkCompiler運行時通過共享Actor實例中的不可變或者不易變的對象、內建代碼塊、方法字節(jié)碼等,提升Actor的啟動性能和節(jié)省內存開銷,達到實現(xiàn)輕量級Actor并發(fā)模型的目標。

4. 跨語言優(yōu)化

HarmonyOS應用在某些情況下實際上是由多種語言的代碼組成的。例如對HarmonyOS JS/TS應用,有一些系統(tǒng)庫、框架和應用依賴的部分能力的實現(xiàn)使用了C/C++和Java語言。HarmonyOS開發(fā)框架也提供了JS/TS與C/C++交互的JS NAPI以及JS/TS與Java交互的Channel機制。考慮不同語言之間的交互場景的開發(fā)和運行效率需求,ArkCompiler和開發(fā)框架聯(lián)合設計,提供了對應的優(yōu)化機制。

(1)JS/TS與C/C++交互

在TS 版本的操作系統(tǒng)平臺API實現(xiàn)中,通常需要面臨C/C++代碼訪問和操作TS對象的場景。對這個業(yè)務場景,ArkCompiler可以根據(jù)TS源碼的class聲明和運行時約定,生成包含TS對象布局描述的C/C++頭文件,以及操作這些TS對象的C/C++實現(xiàn)庫。

在C/C++代碼中,通過包含TS對象描述頭文件以及鏈接對應實現(xiàn)庫,實現(xiàn)直接操作TS對象的效果。需要說明的是,由于TS類型或其內在布局并非總是固定不變的,因此在TS對象操作的代碼實現(xiàn)中,會插入類型檢查,如果對象類型或布局在運行時發(fā)生變化,則回退執(zhí)行通用的慢速路徑。

(2)JS/TS與Java交互

HarmonyOS中有一些應用所需的能力是通過系統(tǒng)、框架或應用的Java庫提供的。因此在HarmonyOS應用中,也存在較多JS/TS代碼與Java代碼交互的場景。常見的案例中,由于JS/TS代碼和Java代碼有各自獨立的運行環(huán)境,相互之間對于對方的數(shù)據(jù)表示、調用約定都是不可知的,所以JS/TS與Java的數(shù)據(jù)交互通常需要經過標準的JSON序列化和反序列化流程,以及經由Native層橋接的相互調用。這造成在一些場景中開銷較大,影響用戶體驗。

ArkCompiler利用同時支持多語言的優(yōu)勢,運行時具備不同語言的數(shù)據(jù)表示、對象布局、函數(shù)調用約定等信息,這使得跨語言之間的直接數(shù)據(jù)訪問、對象操作和方法調用成為可能,同時Java代碼提供的更多確定的類型信息也成為JS/TS類型推導的額外輸入,利于對JS/TS的編譯優(yōu)化。另一方面,這也使我們能為開發(fā)者提供一個更簡化的多語言編程模型,減少需要額外手工編寫的業(yè)務無關的跨語言交互代碼工作量。

四、總結

HarmonyOS所支持的IoT時代下,結合應用生態(tài)、開發(fā)體驗和用戶體驗等方面的需求, ArkCompiler與硬件、操作系統(tǒng)、開發(fā)框架、編程語言協(xié)同設計,在多語言統(tǒng)一編譯運行和多設備支持的基礎上,實現(xiàn)對HarmonyOS應用在開發(fā)和運行效率等方面的提升。

未來,ArkCompiler在持續(xù)優(yōu)化基礎體驗的同時,更會進一步結合HarmonyOS萬物互聯(lián)的需求,在跨端遷移、多端協(xié)同等創(chuàng)新場景,從編譯器和運行時等方面提供底層的解決方案和優(yōu)化機制,提升分布式應用的開發(fā)和運行體驗。

編輯:jq

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 芯片
    +關注

    關注

    456

    文章

    50927

    瀏覽量

    424594
  • 編譯器
    +關注

    關注

    1

    文章

    1635

    瀏覽量

    49171
  • 方舟
    +關注

    關注

    0

    文章

    18

    瀏覽量

    8470
  • 解釋器
    +關注

    關注

    0

    文章

    103

    瀏覽量

    6542

原文標題:HDC技術分論壇:ArkCompiler原理解析

文章出處:【微信號:HarmonyOS_Dev,微信公眾號:HarmonyOS開發(fā)者】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    開源鴻蒙技術論壇在武漢成功舉辦

    ? ? 12月20日,由開放原子開源基金會、中國通信學會主辦,深圳開鴻數(shù)字產業(yè)發(fā)展有限公司(以下簡稱“深開鴻”)協(xié)辦的2024開放原子開發(fā)者大會暨首屆開源技術學術大會——開源鴻蒙技術論壇
    的頭像 發(fā)表于 12-24 13:38 ?168次閱讀

    與鴻同行,探索無限!開源鴻蒙技術論壇在武漢成功舉辦

    12月20日,由開放原子開源基金會、中國通信學會主辦,深圳開鴻數(shù)字產業(yè)發(fā)展有限公司(以下簡稱“深開鴻”)協(xié)辦的2024開放原子開發(fā)者大會暨首屆開源技術學術大會——開源鴻蒙技術論壇在武
    的頭像 發(fā)表于 12-23 21:29 ?235次閱讀
    與鴻同行,探索無限!開源鴻蒙<b class='flag-5'>技術</b><b class='flag-5'>分</b><b class='flag-5'>論壇</b>在武漢成功舉辦

    HDC2080EVM為什么無法安裝MSP430驅動?

    新購入HDC2080EVM,安裝好評估軟件,插入HDC2080EVM,顯示Not Connected, 發(fā)現(xiàn),如下圖MSP430-USB驅動未安裝。 請問,如何解決?謝謝!
    發(fā)表于 12-16 06:42

    AICon北京站HarmonyOS技術論壇開啟招募,歡迎開發(fā)者踴躍報名

    移動應用開發(fā)新范式”為主題的HarmonyOS技術論壇。 本屆論壇將邀請領先企業(yè)伙伴,行業(yè)領袖和技術
    的頭像 發(fā)表于 12-11 16:39 ?188次閱讀
    AICon北京站HarmonyOS<b class='flag-5'>技術</b><b class='flag-5'>分</b><b class='flag-5'>論壇</b>開啟招募,歡迎開發(fā)者踴躍報名

    AICon北京站HarmonyOS技術論壇開啟招募

    AICon北京站HarmonyOS技術論壇將于2024年12月14日在北京與廣大開發(fā)者見面。歡迎各位開發(fā)者踴躍報名,與技術專家現(xiàn)場交流,感受全新的HarmonyOS 開發(fā)體驗。
    發(fā)表于 12-11 09:38

    miniled 技術理解析 miniled與 OLED 比較

    MiniLED技術理解析 MiniLED技術是一種新型的顯示技術,它結合了傳統(tǒng)LED背光技術與MicroLED
    的頭像 發(fā)表于 12-10 15:11 ?1084次閱讀

    HDC3020 EVM用戶指南

    電子發(fā)燒友網(wǎng)站提供《HDC3020 EVM用戶指南.pdf》資料免費下載
    發(fā)表于 12-06 16:08 ?0次下載
    <b class='flag-5'>HDC</b>3020 EVM用戶指南

    汽車制動系統(tǒng)原理解析 如何檢查汽車制動系統(tǒng)

    汽車制動系統(tǒng)原理解析 汽車制動系統(tǒng)是車輛安全行駛的重要組成部分,它的作用是在需要時使車輛減速或停止。現(xiàn)代汽車的制動系統(tǒng)通常包括以下幾個部分:制動踏板、制動總泵、制動泵、制動盤或制動鼓以及制動液
    的頭像 發(fā)表于 11-28 09:40 ?339次閱讀

    HDC302x器件用戶指南

    電子發(fā)燒友網(wǎng)站提供《HDC302x器件用戶指南.pdf》資料免費下載
    發(fā)表于 11-12 15:41 ?0次下載
    <b class='flag-5'>HDC</b>302x器件用戶指南

    HarmonyOS高效測試必備HDC命令

    針對測試人員的需求,HDC 提供了豐富的命令集,幫助他們進行設備連接、日志采集、應用安裝與卸載、性能監(jiān)控等。以下是一些常用且對測試人員非常有幫助的 HDC 命令。
    的頭像 發(fā)表于 10-21 11:42 ?537次閱讀

    Keysight World Tech Day 汽車自動駕駛與新能源技術論壇亮點

    共同參與,歡迎大家報名參與。 論壇 ? 汽車自動駕駛與新能源技術 ? 即將在5月28日上海浦東嘉里大酒店舉辦的Keysight World Tech Day 2024正在火熱報名中. 嘉賓介紹 Sven Kopacz ? 是德
    發(fā)表于 05-15 10:47 ?309次閱讀
    Keysight World Tech Day 汽車自動駕駛與新能源<b class='flag-5'>技術</b><b class='flag-5'>分</b><b class='flag-5'>論壇</b>亮點

    拉普拉斯獨家冠名2024年度ATPV技術論壇,助力產業(yè)科技持續(xù)創(chuàng)新

    年“晶體硅先進光伏技術和材料論壇(ATPV)”春季會議暨“中國材料與試驗標準化委員會(CSTM/FC03/TC22)標準研討會”將于2024年5月15-16日在江蘇省無錫君來湖濱飯店舉行。 據(jù)了解,本次ATPV技術論壇共分為五大
    的頭像 發(fā)表于 05-06 16:24 ?356次閱讀
    拉普拉斯獨家冠名2024年度ATPV<b class='flag-5'>技術</b><b class='flag-5'>分</b><b class='flag-5'>論壇</b>,助力產業(yè)科技持續(xù)創(chuàng)新

    軟通動力成功舉辦“從數(shù)據(jù)到AI,重構生產力”論壇

    3月14日-15日,“華為中國合作伙伴大會2024”在深圳盛大召開。本屆大會不僅匯集了頂尖的思想領袖、商業(yè)精英、技術專家及優(yōu)秀企業(yè)代表,還帶來了多樣化的主題峰會、論壇及圓桌討論等。其中,由軟通動力主辦的“從數(shù)據(jù)到AI,重構生產
    的頭像 發(fā)表于 03-17 15:29 ?675次閱讀

    電磁屏蔽技術的原理解析

    電磁屏蔽技術的原理解析 電磁屏蔽技術是一種利用特定材料或構造來阻擋、吸收或反射外界電磁波的技術。它在電子設備、通信系統(tǒng)以及電磁環(huán)境的凈化等方面具有重要應用,可以有效地防止電磁干擾,保護
    的頭像 發(fā)表于 03-06 14:58 ?2749次閱讀

    arkcompiler_runtime_core/static_core/runtime和arkcompiler_ets_runtime有什么關聯(lián)

    arkcompiler_runtime_core/static_core/runtime有內存分配和垃圾回收,arkcompiler_ets_runtime也有獨立的內存管理和垃圾回收。 這兩個庫之間是什么關系和作用
    發(fā)表于 01-10 21:39
    主站蜘蛛池模板: ts人妖在线| 中文字幕一区二区三区免费看| 天天噜噜日日噜噜久久综合网| 国产一区在线mmai| 白嫩少妇激情无码| 亚洲图片欧美色图| 亚洲免费视频网| 亚洲国产七七久久桃花| 51xtv成人影院| 91大神在线视频观看| 日本在线不卡免| 亚洲人成毛片线播放| 色婷五月综激情亚洲综合| 在线成人欧美| 天天综合色一区二区三区| 日韩成人毛片高清视频免费看| 免费的毛片| 11111日本网站| 丁香六月婷婷综合| 求毛片网站| 精品卡1卡2卡三卡免费视频 | 欧美另类图片亚洲偷| 国产精品自在线天天看片| 日本加勒比高清一本大道| 亚洲vv| 51成人网| 欧美午夜性春猛交bbb| 2019天天干| 黄网站色视频免费观看| 午夜免费福利片| 免费人成黄页在线观看日本| 成人伊人电影| 欧美午夜视频一区二区| 黄篇网站在线观看| 性欧美bbbbbb动漫| 亚洲一二三区在线观看| 污视频18高清在线观看| 亚洲国产成人成上人色| 六月丁香婷婷激情| 夜色综合| 911精品国产91久久久久|