chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

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

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

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

Linux閱碼場 ? 來源:Linuxer ? 2019-11-29 14:34 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

緣起

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

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

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

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

問題一:

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

問題二:

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

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


問題三:

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

問題四:

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

問題五:

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

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

問題六:

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

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

問題七:

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

問題八:

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

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

問題九:

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

問題十:

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

最后

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

最后的最后

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

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

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

    關(guān)注

    3

    文章

    4124

    瀏覽量

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

    關(guān)注

    1

    文章

    1672

    瀏覽量

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

    關(guān)注

    0

    文章

    63

    瀏覽量

    709

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

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

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    技術(shù)分享 | RK3506如何交叉編譯frp wireguard

    之前,我們需要搭建交叉編譯環(huán)境,需要將我司提供的交叉編譯器拷貝至ubuntu中并解壓,完成后如下圖所示:交叉編譯器是從buildroot上直接導(dǎo)出,工具的具體路徑
    的頭像 發(fā)表于 12-25 17:29 ?338次閱讀
    <b class='flag-5'>技術(shù)</b>分享 | RK3506如何交叉<b class='flag-5'>編譯</b>frp wireguard

    性能突破 | SpacemiT-X60 在 LLVM 編譯器上實現(xiàn) 16% 顯著提升

    :ACaseStudyinLLVMOptimizationforRISC-V》。演講基于在進迭時空SpacemiT-X60RISC-V處理上開展的十個月優(yōu)化實踐,系統(tǒng)闡述如何通過上游LLVM的多項改進,顯著提
    的頭像 發(fā)表于 11-21 18:04 ?8725次閱讀
    性能突破 | SpacemiT-X60 在 LLVM <b class='flag-5'>編譯器</b>上實現(xiàn) 16% 顯著提升

    開源鴻蒙技術(shù)大會2025丨編譯器與編程語言分論壇:語言驅(qū)動系統(tǒng)創(chuàng)新,編譯賦能生態(tài)繁榮

    語言設(shè)計演進、編譯器優(yōu)化、工具鏈創(chuàng)新等前沿議題,匯聚產(chǎn)學(xué)研多方力量,共同探討如何通過語言與編譯技術(shù)推動開源鴻蒙生態(tài)向更高效、更智能的方向發(fā)展。
    的頭像 發(fā)表于 11-20 17:24 ?745次閱讀
    開源鴻蒙<b class='flag-5'>技術(shù)</b>大會2025丨<b class='flag-5'>編譯器</b>與編程語言分論壇:語言驅(qū)動系統(tǒng)創(chuàng)新,<b class='flag-5'>編譯</b>賦能生態(tài)繁榮

    飛凌嵌入式ElfBoard-Vim編輯之GCC編譯器的安裝

    GCC(GNU Compiler Collection)是由GNU開發(fā)的編程語言編譯器,最初是作為GNU操作系統(tǒng)的編譯器編寫的。GCC是一編譯器套件,包含很多軟件包,支持多種語言
    發(fā)表于 10-15 08:44

    如何在Keil中將NuMicro BSP從Arm編譯器5遷移到編譯器6?

    在Keil中將NuMicro BSP從Arm編譯器5遷移到編譯器6!
    發(fā)表于 08-20 06:29

    進迭時空同構(gòu)融合RISC-V AI CPU的Triton算子編譯器實踐

    Triton是由OpenAI開發(fā)的一開源編程語言和編譯器,旨在簡化高性能GPU內(nèi)核的編寫。它提供了類似Python的語法,并通過高級抽象降低了GPU編程的復(fù)雜性,同時保持了高性能。目前
    的頭像 發(fā)表于 07-15 09:04 ?1653次閱讀
    進迭時空同構(gòu)融合RISC-V AI CPU的Triton算子<b class='flag-5'>編譯器</b>實踐

    邊緣設(shè)備AI部署:編譯器如何實現(xiàn)輕量化與高性能?

    電子發(fā)燒友網(wǎng)綜合報道 AI編譯器是專門為人工智能(AI)和機器學(xué)習(xí)(ML)模型設(shè)計的編譯器,其核心目標(biāo)是將高級的AI模型描述(如計算圖、神經(jīng)網(wǎng)絡(luò)結(jié)構(gòu))轉(zhuǎn)換為特定硬件平臺(如CPU、GPU、FPGA
    的頭像 發(fā)表于 07-06 05:49 ?6387次閱讀

    編譯器功能安全驗證的關(guān)鍵要素

    在汽車、工業(yè)、醫(yī)療等安全關(guān)鍵型應(yīng)用中,確保功能安全合規(guī)性需要嚴(yán)格的工具鏈驗證。開發(fā)安全關(guān)鍵型軟件的企業(yè)必須遵守ISO 26262、IEC 61508、ISO 62304等國際標(biāo)準(zhǔn)對編譯器工具鏈進行全面的驗證。
    的頭像 發(fā)表于 07-05 13:37 ?1488次閱讀

    兆松科技ZCC編譯器全面支持芯來科技NA系列處理

    近日,兆松科技(武漢)有限公司(以下簡稱“兆松科技”)宣布正式發(fā)布高性能RISC-V編譯器ZCC 4.0.0版本。
    的頭像 發(fā)表于 06-11 09:56 ?1413次閱讀

    RISC-V架構(gòu)下的編譯器自動向量化

    高性能算力生態(tài)的建設(shè),正投入編譯器自動向量化優(yōu)化等多項關(guān)鍵技術(shù),全面助力RISC-V的高性能發(fā)展。RISC-V向量設(shè)計SpacemiT在現(xiàn)代CPU中,向量支持是算力的
    的頭像 發(fā)表于 06-06 16:59 ?1087次閱讀
    RISC-V架構(gòu)下的<b class='flag-5'>編譯器</b>自動向量化

    RVCT編譯器是否比GNU的編譯器的代碼執(zhí)行速度更快?

    使用FX3S遇到了RVCT編譯器的問題。 1、在SDK的release note中有支持RVCT的描述, 但是在EZ USB Suite的設(shè)置中沒有找到RVCT的選項, 請問支持的具體版本
    發(fā)表于 05-08 07:49

    HighTec編譯器全面支持芯馳科技車規(guī)MCU芯片E3650

    近日,HighTec與芯馳科技共同宣布HighTec編譯器套件將全面支持芯馳新一代旗艦智控MCU-E3650芯片。此次合作,進一步豐富了芯馳車芯產(chǎn)品的工具鏈生態(tài),雙方將攜手為客戶提供高性能、高安全性的解決方案。
    的頭像 發(fā)表于 04-28 15:20 ?1660次閱讀

    HighTec編譯器全面適配紫光同芯THA6 Gen2系列產(chǎn)品

    近日,紫光同芯與全球領(lǐng)先的汽車級C/C++編譯器供應(yīng)商HighTec共同宣布,HighTec編譯器完成對紫光同芯THA6 Gen2系列產(chǎn)品的全面適配。此次合作實現(xiàn)了從指令集優(yōu)化到功能安全的全棧支持,是國產(chǎn)高端車規(guī)芯片與國際領(lǐng)先開發(fā)工具的深度
    的頭像 發(fā)表于 04-02 09:42 ?1005次閱讀

    Microchip推出MPLAB? XC統(tǒng)一編譯器許可證 更高效的管理多個許可證

    Microchip推出MPLAB XC統(tǒng)一編譯器許可證,簡化軟件管理? 為了提供一種高效的方式來管理多個許可證,Microchip Technology Inc.(微芯科技公司)今日推出適用于其
    的頭像 發(fā)表于 02-25 17:35 ?1607次閱讀

    適用于PIC MCU的MPLAB XC8 C編譯器用戶指南

    電子發(fā)燒友網(wǎng)站提供《適用于PIC MCU的MPLAB XC8 C編譯器用戶指南.pdf》資料免費下載
    發(fā)表于 01-22 16:45 ?0次下載
    適用于PIC MCU的MPLAB XC8 C<b class='flag-5'>編譯器</b>用戶指南