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

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

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

3天內不再提示

ArkUI,更高效的框架設計

HarmonyOS開發者 ? 來源:未知 ? 2022-12-21 09:15 ? 次閱讀

上期文章我們講到了ArkUI的三大特性,同時提到了ArkUI是一套用于構建HarmonyOS應用界面的UI開發框架,本期我們將從架構設計上來聊聊ArkUI的設計理念。

daa6ca04-80cc-11ed-8abf-dac502259ad0.png

ArkUI架構圖

從架構圖可以看出,ArkUI的設計理念是在端到端整條技術路徑設計上建立了一整套完整的分層機制。接下來我們依次分層為大家介紹。

ArkUI框架的“前驅”——【前端層】

dab7c5c0-80cc-11ed-8abf-dac502259ad0.png

前端層

架構的第一層【前端層】又稱【聲明式UI前端】,這一層包含了上期文章介紹的極簡的UI信息語法規范,UI組件以及ArkTS語言特有的狀態管理機制。

dad6fc74-80cc-11ed-8abf-dac502259ad0.gif

獨立的封裝

此外,ArkUI對常用的UI組件的結構、樣式、事件三大屬性進行了獨立的封裝,內置于SDK中。開發人員可以根據項目設計需求,調用與設計匹配的組件函數,傳入相應的參數來完成UI描述。

db018a48-80cc-11ed-8abf-dac502259ad0.png

聲明式UI信息語法

同時使用聲明式UI信息語法,可以讓數據和View進行聯動更新,華為自研語言ArkTS為這種聯動刷新提供了多維度的狀態管理機制,開發人員通過對數據進行注釋標記,合理控制數據對應View的更新作用范圍。

db14aab0-80cc-11ed-8abf-dac502259ad0.gif

三種更新方式

如:只單獨更新、父子單向更新,父子雙向同步更新等。

到這里,第一層【前端層】就介紹完畢了。

ArkUI框架的“核心部分”——【核心層】

接下來我們來到了框架的第二層【核心層】。

db37a920-80cc-11ed-8abf-dac502259ad0.png

核心層

這一層主要包含兩部分【方舟編譯運行時】和【聲明式UI后端引擎】。

db4d8efc-80cc-11ed-8abf-dac502259ad0.png

方舟編譯運行時

【核心層】的第一部分是【方舟編譯運行時】,它涉及到開發環境和終端環境

db6a4e66-80cc-11ed-8abf-dac502259ad0.png

運行流程圖

【方舟編譯運行時】的流程包含4步

db7acd5e-80cc-11ed-8abf-dac502259ad0.gif

跨語言調用

第1步是跨語言調用

ArkUI在開發項目時支持多語言開發,為不同的開發語言相互通信提供了通道,例如:提供了JS/TS與C/ C++交互的NAPI機制。

dbddfb86-80cc-11ed-8abf-dac502259ad0.png

新語言ArkTS

而在ArkUI支持的多種語言中,ArkTS是以TS為語法基礎的應用編程語言。

dbf427bc-80cc-11ed-8abf-dac502259ad0.png

類型系統

在預編譯的過程中,數據的靜態類型信息會攜帶在生成的統一字節碼中,后端編譯的時候能直接利用這種類型信息加速機器碼的執行,避免了運行時收集對象造成的額外開銷,同時這些類型信息被用于AOT編譯過程,使得應用啟動時就可以執行AOT生成的優化機器碼獲得高性能運行體驗。

dc0a46a0-80cc-11ed-8abf-dac502259ad0.png

統一字節碼

第2步是統一字節碼

完成項目開發將項目進行打包時,方舟編譯器將編寫的高級編程語言通過內置的工具鏈,編譯為一種與運行設備和系統無關的可移植介質,這種介質就叫統一字節碼(又稱方舟碼,abc文件),這個過程也稱為字節碼預編譯。

dc1a3506-80cc-11ed-8abf-dac502259ad0.png

統一字節碼

第3步是機器碼和安裝包

字節碼在設備上可以通過解釋執行或者編譯后執行的方式運行,對于執行性能要求高的部分字節碼調用AOT生成機器碼。

最后,應用經歷了開發、字節碼預編譯、AOT靜態優化編譯、打包簽名就形成了一個完整安裝包,這樣一來就終于可以在設備上運行預覽了。

dc368abc-80cc-11ed-8abf-dac502259ad0.png

GC機制

第4步是GC(Garbage Collection)機制

dc4db00c-80cc-11ed-8abf-dac502259ad0.png

搭載HarmonyOS系統的設備

對比其他設備,搭載HarmonyOS系統的設備上運行應用時會顯得特別流暢,這里的秘密是什么呢?

dc68123a-80cc-11ed-8abf-dac502259ad0.png

GC機制技術問題

由于在傳統的操作系統中,基于Tracing的GC存在著STW(Stop The World)階段暫停時間較長的問題。

dc79b72e-80cc-11ed-8abf-dac502259ad0.png

STW

手機內存資源不夠用的時候,傳統操作系統虛擬機就會召喚GC(Garbage Collection)封鎖公路,暫停手機運行的所有線程,等待它回收內存空間。

STW暫停時間較長

而且STW(Stop The World)階段的暫停時間段較長,開發者無法精確控制和干預,在性能較差的手機上會表現出較強的“間歇性”卡頓。這就好比行駛在市區道路的車輛,在經過每個路口都遇到了較長時間的紅燈等待,一路走走停停,行駛體驗感較差。

ddd195f6-80cc-11ed-8abf-dac502259ad0.png

HPP GC

而方舟編譯運行時在內存回收方面重新設計,基于Tracing GC推出了高性能內存回收技術——HPP GC(High Performance Partial Garbage Collection)。HPP GC綜合了多種Tracing GC算法,根據不同對象區域,采用不同的回收方式。這種GC機制可以縮短STW階段的時長,用在市區駕駛車輛來比喻,就是縮短了車輛在路口紅燈等待的時間,增加了行駛的體驗感。

ddec4ba8-80cc-11ed-8abf-dac502259ad0.gif

HPP GC

接下來我們來看核心層的第二部分——聲明式UI后端引擎。

它在HarmonyOS系統終端運行時,由C++編寫UI的基本組件、布局、動效和事件組成。供UI前端開發人員調用。

de127f80-80cc-11ed-8abf-dac502259ad0.gif

渲染管線

渲染管線是位于運行時內部的一個獨立的渲染線程,它負責支配CPU多線程地去工作,讓CPU為GPU提供更多的渲染數據,最大額度的調取GPU的能力。

到此,【核心層】已全部介紹完畢。

通過本期ArkUI架構的學習,相信大家已經了解方舟編譯運行時的技術和流程,也對ArkUI的設計理念有了基礎的認識。完整版的內容可查看上方的視頻,我們下期再見~

END

想了解更多HarmonyOS技術?

后臺留言給我們

立刻安排!


原文標題:ArkUI,更高效的框架設計

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


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

    關注

    79

    文章

    2005

    瀏覽量

    31680

原文標題:ArkUI,更高效的框架設計

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

收藏 人收藏

    評論

    相關推薦

    GaN如何實現更高效、更緊湊的電源

    電子發燒友網站提供《GaN如何實現更高效、更緊湊的電源.pdf》資料免費下載
    發表于 09-12 10:00 ?0次下載
    GaN如何實現<b class='flag-5'>更高效</b>、更緊湊的電源

    如何使用PyTorch構建更高效的人工智能

    術界和工業界得到了廣泛應用。本文將深入探討如何使用PyTorch構建更高效的人工智能系統,從框架基礎、模型訓練、實戰應用等多個方面進行詳細解析。
    的頭像 發表于 07-02 13:12 ?588次閱讀

    ArkUI-X開發指南:【SDK配置和構建說明】

    ArkUI-X SDK是ArkUI-X開源項目的編譯產物,可將ArkUI-X SDK集成到現有Android和iOS應用工程中,使開發者基于一套ArkTS主代碼,就可以構建支持多平臺的精美、高性能應用。SDK內容包含
    的頭像 發表于 05-25 16:48 ?3111次閱讀
    <b class='flag-5'>ArkUI</b>-X開發指南:【SDK配置和構建說明】

    鴻蒙開發ArkUI-X基礎知識:【ArkUI代碼工程及構建介紹】

    ArkUI作為OpenHarmony的默認開發框架,在本項目(ArkUI-X)中需要做到一套代碼同時支持多平臺構建,所以會采取共倉開發的方式,部分倉直接指向OpenHarmony相關開源倉。
    的頭像 發表于 05-25 16:45 ?2480次閱讀
    鴻蒙開發<b class='flag-5'>ArkUI</b>-X基礎知識:【<b class='flag-5'>ArkUI</b>代碼工程及構建介紹】

    鴻蒙ArkUI-X跨語言調用說明:【平臺橋接開發指南(Android)】

    平臺橋接用于客戶端(ArkUI)和平臺(Android或iOS)之間傳遞消息,即用于ArkUI與平臺雙向數據傳遞、ArkUI側調用平臺的方法、平臺調用ArkUI側的方法。本文主要介紹A
    的頭像 發表于 05-25 16:26 ?986次閱讀
    鴻蒙<b class='flag-5'>ArkUI</b>-X跨語言調用說明:【平臺橋接開發指南(Android)】

    鴻蒙開發ArkUI-X基礎知識:【ArkUI跨平臺設計總體說明】

    本文檔描述ArkUI開發框架跨平臺運行能力相關的總體技術方案。
    的頭像 發表于 05-24 15:41 ?1891次閱讀
    鴻蒙開發<b class='flag-5'>ArkUI</b>-X基礎知識:【<b class='flag-5'>ArkUI</b>跨平臺設計總體說明】

    鴻蒙ArkUI-X跨平臺技術:【開發準備】

    本文檔適用于ArkUI跨平臺應用開發的初學者。通過開發環境搭建、應用工程創建、編譯和運行,熟悉ArkUI跨平臺應用開發基本流程。
    的頭像 發表于 05-24 10:40 ?735次閱讀
    鴻蒙<b class='flag-5'>ArkUI</b>-X跨平臺技術:【開發準備】

    鴻蒙ArkUI-X框架開發:【開發準備】

    本文檔適用于ArkUI-X框架開發的初學者。通過環境搭建、代碼下載、代碼編譯、API擴展和使用,快速了解跨平臺項目開發流程。
    的頭像 發表于 05-23 21:02 ?638次閱讀
    鴻蒙<b class='flag-5'>ArkUI</b>-X<b class='flag-5'>框架</b>開發:【開發準備】

    鴻蒙ArkUI-X跨語言調用說明:【平臺橋接(@arkui-x.bridge)】

    平臺橋接用于客戶端(ArkUI)和平臺(Android或iOS)之間傳遞消息,即用于ArkUI與平臺雙向數據傳遞、ArkUI側調用平臺的方法、平臺調用ArkUI側的方法。
    的頭像 發表于 05-21 15:09 ?1045次閱讀
    鴻蒙<b class='flag-5'>ArkUI</b>-X跨語言調用說明:【平臺橋接(@<b class='flag-5'>arkui</b>-x.bridge)】

    鴻蒙ArkUI-X跨平臺開發:【SDK目錄結構介紹】

    本文檔配套ArkUI-X,將OpenHarmony ArkUI開發框架擴展到不同的OS平臺,比如Android和iOS平臺,讓開發者基于ArkUI,可復用大部分的應用代碼(UI以及主要
    的頭像 發表于 05-20 16:28 ?1037次閱讀
    鴻蒙<b class='flag-5'>ArkUI</b>-X跨平臺開發:【SDK目錄結構介紹】

    鴻蒙ArkUI-X跨平臺開發:【 應用工程結構說明】

    本文檔配套ArkUI-X,將OpenHarmony ArkUI開發框架擴展到不同的OS平臺,比如Android和iOS平臺,讓開發者基于ArkUI,可復用大部分的應用代碼(UI以及主要
    的頭像 發表于 05-19 21:05 ?774次閱讀
    鴻蒙<b class='flag-5'>ArkUI</b>-X跨平臺開發:【 應用工程結構說明】

    鴻蒙ArkUI-X跨平臺技術:【概述】

    ArkUI是一套構建分布式應用的聲明式UI開發框架。它具備簡潔自然的UI信息語法、豐富的UI組件、多維的狀態管理,以及實時界面預覽等相關能力,幫助您提升應用開發效率,并能在多種設備上實現生動而流暢的用戶體驗。
    的頭像 發表于 05-16 16:19 ?2579次閱讀
    鴻蒙<b class='flag-5'>ArkUI</b>-X跨平臺技術:【概述】

    鴻蒙跨平臺框架:【ArkUi-X】創建工程

    鴻蒙推出了鴻ArkUi-X 框架所以就寫個文章分享一下
    的頭像 發表于 05-13 17:48 ?1263次閱讀
    鴻蒙跨平臺<b class='flag-5'>框架</b>:【<b class='flag-5'>ArkUi</b>-X】創建工程

    鴻蒙ArkUI:【從代碼到UI顯示的整體渲染流程】

    方舟開發框架(簡稱ArkUI)是鴻蒙開發的UI框架,提供如下兩種開發范式,我們 **只學聲明式開發范式**
    的頭像 發表于 05-13 16:06 ?1278次閱讀
    鴻蒙<b class='flag-5'>ArkUI</b>:【從代碼到UI顯示的整體渲染流程】

    鴻蒙開發學習:初探【ArkUI-X】

    **簡單來說,ArkTS + ArkUI-X 對標的框架為 flutter,一次代碼,編譯為 native 全平臺運行**
    的頭像 發表于 05-13 15:58 ?1379次閱讀
    鴻蒙開發學習:初探【<b class='flag-5'>ArkUI</b>-X】
    主站蜘蛛池模板: 日本久久黄色 | 天天综合网天天综合色不卡 | 制服丝袜中文字幕第一页 | 男男gay高h文 | 丁香花在线电影小说观看 | 国内一级特黄女人精品毛片 | 色综合天天综一个色天天综合网 | 年轻的护士3 | 韩国三级理论在线看中文字幕 | 亚洲女同一区二区 | 美女扒开尿口给男人看的让 | 天天干夜夜想 | 青娱乐久草 | 黄色在线视频网 | 91人成网站色www免费 | aaaaaaa欧美黄色大片 | 天天操天天舔天天干 | 婷婷在线网站 | 国产片91人成在线观看 | 午夜影院黄色片 | 国产欧美另类第一页 | 久久久午夜精品 | 国产亚洲精品美女2020久久 | 天堂网最新版www | 高清国产下药迷倒美女 | 色网视频 | 一级欧美一级日韩 | 青草网址 | 成人看的午夜免费毛片 | 久久国产视频一区 | 日韩三级精品 | 成人精品一区二区不卡视频 | 九九人人| 亚州国产精品精华液 | 国产一区二区在线观看免费 | 久久成人综合 | 三级黄色在线 | 日本在线网址 | 亚洲免费在线看 | 欧美精品 在线播放 | 中文在线最新版天堂bt |