国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

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

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

3天內不再提示

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

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

掃碼添加小助手

加入工程師交流群

緣起

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

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

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

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

問題一:

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

問題二:

編譯器領域現在業界都使用三段式編譯器。架構如下:

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


問題三:

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

問題四:

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

問題五:

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

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

問題六:

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

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

問題七:

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

問題八:

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

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

問題九:

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

問題十:

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

最后

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

最后的最后

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

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

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

    關注

    3

    文章

    4207

    瀏覽量

    46149
  • 編譯器
    +關注

    關注

    1

    文章

    1672

    瀏覽量

    51618
  • 方舟編譯器
    +關注

    關注

    0

    文章

    63

    瀏覽量

    767

原文標題:鄧凡平:技術探討之請教方舟編譯器的十個問題

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

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    技術分享 | RK3506如何交叉編譯frp wireguard

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

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

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

    開源鴻蒙技術大會2025丨編譯器與編程語言分論壇:語言驅動系統創新,編譯賦能生態繁榮

    語言設計演進、編譯器優化、工具鏈創新等前沿議題,匯聚產學研多方力量,共同探討如何通過語言與編譯技術推動開源鴻蒙生態向更高效、更智能的方向發展。
    的頭像 發表于 11-20 17:24 ?925次閱讀
    開源鴻蒙<b class='flag-5'>技術</b>大會2025丨<b class='flag-5'>編譯器</b>與編程語言分論壇:語言驅動系統創新,<b class='flag-5'>編譯</b>賦能生態繁榮

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

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

    GCC編譯器,怎么才能實現c文件中未被調用的函數,不會被編譯呢?

    GCC編譯器,怎么才能實現c文件中未被調用的函數,不會被編譯?有什么編譯選項可以設置嗎? 移植代碼,有些函數沒被調用的函數想留在代碼里,但不想被編譯
    發表于 09-28 12:25

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

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

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

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

    邊緣設備AI部署:編譯器如何實現輕量化與高性能?

    電子發燒友網綜合報道 AI編譯器是專門為人工智能(AI)和機器學習(ML)模型設計的編譯器,其核心目標是將高級的AI模型描述(如計算圖、神經網絡結構)轉換為特定硬件平臺(如CPU、GPU、FPGA
    的頭像 發表于 07-06 05:49 ?6647次閱讀

    編譯器功能安全驗證的關鍵要素

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

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

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

    RISC-V架構下的編譯器自動向量化

    高性能算力生態的建設,正投入編譯器自動向量化優化等多項關鍵技術,全面助力RISC-V的高性能發展。RISC-V向量設計SpacemiT在現代CPU中,向量支持是算力的
    的頭像 發表于 06-06 16:59 ?1235次閱讀
    RISC-V架構下的<b class='flag-5'>編譯器</b>自動向量化

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

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

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

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

    HighTec編譯器全面適配紫光同芯THA6 Gen2系列產品

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

    請問基于GCC編譯器的initcall在STM32如何實現?

    請問各位基于GCC編譯器的initcall在STM32如何實現?有哪位實現了嗎?
    發表于 03-13 06:24