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

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

技術(shù)探討之請(qǐng)教方舟編譯器的十個(gè)問題

Linux閱碼場 ? 來源:Linuxer ? 2019-11-29 14:34 ? 次閱讀

緣起

華為的方舟編譯器終于走出開源的第一步,官方地址為https://www.openarkcompiler.cn/home 。我個(gè)人于今年4月在機(jī)械工業(yè)出版社出版了“深入理解Android”系列書籍的最后一本書——《深入理解Android Java虛擬機(jī)ART》一書。

這本書圍繞Android系統(tǒng)中Java虛擬機(jī)ART做了詳盡的源碼分析。其中,第六章更是以全書最多的篇幅從字節(jié)碼到機(jī)器碼的編譯過程進(jìn)行了詳細(xì)介紹。

寫書時(shí),我一直耿耿于懷國內(nèi)在計(jì)算機(jī)基礎(chǔ)核心技術(shù)上缺乏領(lǐng)軍公司的投入之時(shí),沒想到今年華為先送出方舟編譯器,緊接其后是鴻蒙OS。未來不敢說結(jié)局怎樣,但現(xiàn)時(shí)真切讓我和我周圍的小伙伴看到了希望。就算激起無論是正面還是負(fù)面的全民大討論,我覺得相比無人問津也算是大大的進(jìn)步。

言歸正傳,結(jié)合方舟的官網(wǎng),我其實(shí)有幾個(gè)技術(shù)問題想請(qǐng)教。當(dāng)然,隨著方舟進(jìn)一步擴(kuò)大和深度開源,這些問題可能也就不言自明。到時(shí)候感興趣的讀者不妨以這里提到的問題來看看方舟是如何巧妙解決它們的。

問題一:

https://www.openarkcompiler.cn/document/FAQ Q2說“當(dāng)前部分Java語言特性和JVM虛擬機(jī)特性的支持未包括在本次開源代碼中,包括:annotation、lambda表達(dá)式、泛型等”。想了解下,這部分功能是否已經(jīng)在方舟編譯器上實(shí)現(xiàn)但目前還未開源出來?還是什么別的情況?出于什么考慮,lambda表達(dá)式和泛型未能在此時(shí)開源?

問題二:

編譯器領(lǐng)域現(xiàn)在業(yè)界都使用三段式編譯器。架構(gòu)如下:

編譯器框架LLVM和核心就是LLVM IR,而方舟編譯器也有一個(gè)Maple IR。請(qǐng)問相比LLVM IR,Maple IR的優(yōu)勢(shì)在哪里?它的愿景是什么?


問題三:

經(jīng)過方舟編譯器處理后的應(yīng)用,從公開渠道上的信息上看,在流暢度等幾個(gè)方面有大幅提升。能否詳細(xì)介紹下流暢度是怎么衡量的?也就是說,方舟內(nèi)部是如何評(píng)價(jià)經(jīng)過方舟編譯器處理后以及沒有經(jīng)過方舟編譯器處理后的應(yīng)用的性能?都選了哪些測試點(diǎn)

問題四:

適配了方舟編譯器的有幾十個(gè)APP,但還有很多APP開發(fā)者沒有機(jī)會(huì)第一時(shí)間接觸方舟(包括我自己)。想了解下使用方舟編譯器是否有副作用?比如,如果將字節(jié)碼全部轉(zhuǎn)成了機(jī)器碼,這會(huì)占據(jù)較大的存儲(chǔ)空間。請(qǐng)問是否有類似這樣的問題,有什么好的解決辦法嗎?

問題五:

方舟編譯器說干掉了JVM虛擬機(jī)(原話可能不是如此,但我理解是這個(gè)意思),請(qǐng)問經(jīng)過方舟編譯器處理的應(yīng)用是否能按以前的Java程序那樣調(diào)試?

備注:為什么會(huì)問這個(gè)問題?java程序debug時(shí)必須靠jvm幫忙,比如處理jdwp,更關(guān)鍵是要靠jvm來解釋執(zhí)行字節(jié)碼。不過,我在ART那本書里并沒有詳細(xì)介紹這個(gè)過程,我不保證這個(gè)問題問正確了。也請(qǐng)懂行的朋友們指正。

問題六:

方舟編譯器對(duì)java語言的特性支持如何?比如,ART虛擬機(jī)中,一個(gè)java方法即使以機(jī)器碼方式運(yùn)行,在某些時(shí)候也必須回退到解釋執(zhí)行。比如下面的ArrayIndexOutOfBounds異常的處理。

對(duì)于類似這種問題,方舟編譯器在技術(shù)層面上對(duì)于它們大概的解決思路是什么?

問題七:

ART虛擬機(jī)在諸如synchronized等的實(shí)現(xiàn)上做了大量工作(ART一書的第十二章),包括優(yōu)化(比如一個(gè)線程如果已經(jīng)得到某個(gè)鎖的情況下,后續(xù)再去獲取這個(gè)鎖的話,實(shí)際上只是遞增了該鎖的引用計(jì)數(shù))。雖然PTHREAD相關(guān)同步處理也有類似的優(yōu)化,但我想了解下方舟編譯器(如果干掉虛擬機(jī)的話),有沒有針對(duì)這方面的處理或者優(yōu)化?

問題八:

引用計(jì)數(shù)是垃圾回收的一種經(jīng)典技術(shù)。方舟編譯器說是用引用計(jì)數(shù)代替了其它幾種GC技術(shù),做到隨用隨收。但其中有一些需要特別注意的地方(ART一書的第十三章、十四章專門講解內(nèi)存分配和GC)。垃圾回收是和內(nèi)存分配息息相關(guān)的。ART虛擬機(jī)內(nèi)部對(duì)內(nèi)存分配有著良好的管理。比如rosalloc分配器,BumpPointerSpace、針對(duì)大內(nèi)存對(duì)象的LargeObjectSpace等。請(qǐng)問方舟編譯器是怎么應(yīng)對(duì)的?是將java層的new直接對(duì)應(yīng)到比如native層的new/malloc(直接依賴os的內(nèi)存分配機(jī)制),還是也依賴一個(gè)小的,輕量級(jí)的runtime來協(xié)助這方面的工作?

另外,ART在內(nèi)存管理方面做了一些優(yōu)化,比如當(dāng)程序退到后臺(tái)后,會(huì)對(duì)內(nèi)存進(jìn)行碎片整理。如果方舟編譯器是隨用隨收的話,請(qǐng)問長時(shí)間運(yùn)行后,是否會(huì)存在內(nèi)存碎片?如果有,是如何處理的呢?

問題九:

官網(wǎng)上提到了伴隨方舟編譯器有一個(gè)輕量級(jí)的運(yùn)行時(shí),這個(gè)運(yùn)行時(shí)主要工作是什么?它和ART JVM有何區(qū)別?方舟編譯器未來還要支持Javascript,這個(gè)運(yùn)行時(shí)是否也能支持JS?還是說需要一個(gè)針對(duì)js的運(yùn)行時(shí)?最后,這個(gè)運(yùn)行時(shí)會(huì)開源嗎?

問題十:

我想方舟編譯器的背后是承載了華為甚至很多國人偉大夢(mèng)想的,但一時(shí)領(lǐng)先并不保證長久領(lǐng)先。比如,媒體做了經(jīng)過方舟編譯器處理后APP和蘋果手機(jī)上APP打開速度的對(duì)比測試。方舟編譯器的效果比較明顯。但ios13據(jù)蘋果官方數(shù)據(jù)上看,APP啟動(dòng)速度提升了兩倍。這說明我們?cè)谂Γ瑢?duì)手也在努力。華為是一個(gè)有著很強(qiáng)憂患意識(shí)的偉大公司。那么,方舟編譯器針對(duì)ios13是否有優(yōu)勢(shì)?我們這個(gè)優(yōu)勢(shì)會(huì)不會(huì)很容易被對(duì)手顛覆呢?我們?cè)撊绾闻Γ膫€(gè)方向努力呢?

最后

無論怎樣,方舟編譯器都會(huì)在IT歷史上留下濃重的筆墨。衷心期望我個(gè)人或其它朋友能為我們自己的IT成果——方舟編譯器、鴻蒙OS等編寫學(xué)習(xí)資料,貢獻(xiàn)自己的微薄力量。

最后的最后

我期望的結(jié)果不是朋友們從我的書、文章、博客后學(xué)會(huì)了什么知識(shí),干成了什么,而應(yīng)該是說,神農(nóng),我可是踩在你的肩膀上的喔。

關(guān)于學(xué)習(xí)方面的問題,我已經(jīng)討論完了。后面這個(gè)公眾號(hào)將對(duì)一些基礎(chǔ)的技術(shù),新技術(shù)做一些學(xué)習(xí)和分享。也歡迎你的投稿。不過,正如我在公眾號(hào)“聯(lián)系方式”里說的那樣——鄭淵潔在童話大王《智齒》里有一句話令我印象深刻,大意是“我有權(quán)保持沉默,但你說的每一句話都可能成為我靈感的源泉”。所以,影響不是單向的,很可能我從你那學(xué)到的東西更多。

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

    關(guān)注

    3

    文章

    3156

    瀏覽量

    42101
  • 編譯器
    +關(guān)注

    關(guān)注

    1

    文章

    1602

    瀏覽量

    48916
  • 方舟編譯器
    +關(guān)注

    關(guān)注

    0

    文章

    60

    瀏覽量

    175

原文標(biāo)題:鄧凡平:技術(shù)探討之請(qǐng)教方舟編譯器的十個(gè)問題

文章出處:【微信號(hào):LinuxDev,微信公眾號(hào):Linux閱碼場】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    AI編譯器技術(shù)剖析

    隨著人工智能技術(shù)的飛速發(fā)展,AI編譯器作為一種新興的編譯技術(shù)逐漸進(jìn)入人們的視野。AI編譯器不僅具備傳統(tǒng)
    的頭像 發(fā)表于 07-17 18:28 ?1244次閱讀

    人工智能編譯器與傳統(tǒng)編譯器的區(qū)別

    人工智能編譯器(AI編譯器)與傳統(tǒng)編譯器在多個(gè)方面存在顯著的差異。這些差異主要體現(xiàn)在設(shè)計(jì)目標(biāo)、功能特性、優(yōu)化策略、適用范圍以及技術(shù)復(fù)雜性等方面。以下是對(duì)兩者區(qū)別的詳細(xì)
    的頭像 發(fā)表于 07-17 18:19 ?1345次閱讀

    深度學(xué)習(xí)編譯器和推理引擎的區(qū)別

    深度學(xué)習(xí)編譯器和推理引擎在人工智能領(lǐng)域中都扮演著至關(guān)重要的角色,但它們各自的功能、應(yīng)用場景以及優(yōu)化目標(biāo)等方面存在顯著的差異。以下是對(duì)兩者區(qū)別的詳細(xì)探討
    的頭像 發(fā)表于 07-17 18:12 ?1066次閱讀

    Meta發(fā)布基于Code Llama的LLM編譯器

    近日,科技巨頭Meta在其X平臺(tái)上正式宣布推出了一款革命性的LLM編譯器,這一模型家族基于Meta Code Llama構(gòu)建,并融合了先進(jìn)的代碼優(yōu)化和編譯器功能。LLM編譯器的推出,標(biāo)志著Meta在人工智能領(lǐng)域的又一重大突破,將
    的頭像 發(fā)表于 06-29 17:54 ?1325次閱讀

    SEGGER編譯器優(yōu)化和安全技術(shù)介紹 支持最新C和C++語言

    SEGGER編譯器是專門為ARM和RISC-V微控制設(shè)計(jì)的優(yōu)化C/C++編譯器。它建立在強(qiáng)大的Clang前端上,支持最新的C和C++語言功能。 除其他外,其主要功能包括: 1)?尺寸優(yōu)化:通過調(diào)整
    的頭像 發(fā)表于 06-04 15:31 ?1191次閱讀
    SEGGER<b class='flag-5'>編譯器</b>優(yōu)化和安全<b class='flag-5'>技術(shù)</b>介紹 支持最新C和C++語言

    具有十個(gè)解碼輸出的進(jìn)位計(jì)數(shù)/除法器數(shù)據(jù)表

    電子發(fā)燒友網(wǎng)站提供《具有十個(gè)解碼輸出的進(jìn)位計(jì)數(shù)/除法器數(shù)據(jù)表.pdf》資料免費(fèi)下載
    發(fā)表于 05-17 10:47 ?0次下載
    具有<b class='flag-5'>十個(gè)</b>解碼輸出的<b class='flag-5'>十</b>進(jìn)位計(jì)數(shù)<b class='flag-5'>器</b>/除法器數(shù)據(jù)表

    QT開發(fā)學(xué)習(xí)筆記1(安裝交叉編譯器

    QT安裝交叉編譯器
    的頭像 發(fā)表于 02-18 10:02 ?715次閱讀
    QT開發(fā)學(xué)習(xí)筆記1(安裝交叉<b class='flag-5'>編譯器</b>)

    Triton編譯器的原理和性能

    Triton是一種用于編寫高效自定義深度學(xué)習(xí)原語的語言和編譯器。Triton的目的是提供一個(gè)開源環(huán)境,以比CUDA更高的生產(chǎn)力編寫快速代碼,但也比其他現(xiàn)有DSL具有更大的靈活性。Triton已被采用
    的頭像 發(fā)表于 12-16 11:22 ?2303次閱讀
    Triton<b class='flag-5'>編譯器</b>的原理和性能

    TVM編譯器的整體架構(gòu)和基本方法

    有將近兩個(gè)月沒有學(xué)習(xí)一些新東西,更新一下博客了。一直在忙公司的一個(gè)項(xiàng)目,是做一款支持LSTM和RNN的通用架構(gòu)加速IP。自己恰好負(fù)責(zé)指令編譯工作,雖然開始的指令比較粗糙,沒有一套完整的編譯器架構(gòu)
    的頭像 發(fā)表于 11-30 09:36 ?1942次閱讀
    TVM<b class='flag-5'>編譯器</b>的整體架構(gòu)和基本方法

    編譯器的優(yōu)化選項(xiàng)

    個(gè)程序首先要保證正確性,在保證正確性的基礎(chǔ)上,性能也是一個(gè)重要的考量。要編寫高性能的程序,第一,必須選擇合適的算法和數(shù)據(jù)結(jié)構(gòu);第二,應(yīng)該編寫編譯器能夠有效優(yōu)化以轉(zhuǎn)換成高效可執(zhí)行代碼的源代碼,要做到
    的頭像 發(fā)表于 11-24 15:37 ?767次閱讀
    <b class='flag-5'>編譯器</b>的優(yōu)化選項(xiàng)

    接口調(diào)用并發(fā)執(zhí)行十個(gè)任務(wù)總結(jié)

    個(gè)接口調(diào)用時(shí),接收到一個(gè)列表,十個(gè)元素,需要并發(fā)執(zhí)行十個(gè)任務(wù),每個(gè)任務(wù)都要返回執(zhí)行的結(jié)果和異常,然后對(duì)返回的結(jié)果裝填到一個(gè)切片列表里,統(tǒng)一
    的頭像 發(fā)表于 11-15 10:37 ?361次閱讀

    嵌入式j(luò)avascript編譯器的設(shè)計(jì)與實(shí)現(xiàn)

    電子發(fā)燒友網(wǎng)站提供《嵌入式j(luò)avascript編譯器的設(shè)計(jì)與實(shí)現(xiàn).pdf》資料免費(fèi)下載
    發(fā)表于 10-30 11:29 ?0次下載
    嵌入式j(luò)avascript<b class='flag-5'>編譯器</b>的設(shè)計(jì)與實(shí)現(xiàn)

    新版編譯器的設(shè)計(jì)思路和優(yōu)化方法

    小程序編譯器在小程序開發(fā)、預(yù)覽、發(fā)布各個(gè)階段都需要使用,因此編譯器性能會(huì)直接影響到開發(fā)者開發(fā)效率,也會(huì)影響到開發(fā)者工具的使用體驗(yàn)。 由于舊版的編譯器(基于 webpack4)在構(gòu)建大型項(xiàng)目時(shí)會(huì)很慢,內(nèi)存占用也高,一直被開發(fā)者吐槽
    發(fā)表于 10-13 11:21 ?264次閱讀
    新版<b class='flag-5'>編譯器</b>的設(shè)計(jì)思路和優(yōu)化方法

    嵌入式開發(fā)中的C語言編譯器設(shè)置

    編譯器的語義檢查很弱小,甚至還會(huì)“掩蓋”錯(cuò)誤?,F(xiàn)代的編譯器設(shè)計(jì)是件浩瀚的工程,為了讓編譯器設(shè)計(jì)簡單一些,目前幾乎所有編譯器的語義檢查都比較弱小。為了獲得更快的執(zhí)行效率,C語言被設(shè)計(jì)的足
    發(fā)表于 10-11 12:43 ?584次閱讀

    OpenHarmony 的js引擎用的是方舟編譯器

    OpenHarmony 的js引擎用的是方舟編譯器嗎?方舟編譯器不是用來編譯嗎?
    發(fā)表于 10-09 09:32