一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

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

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

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

ArkUI,更高效的框架設(shè)計

HarmonyOS開發(fā)者 ? 來源:未知 ? 2022-12-21 09:15 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

上期文章我們講到了ArkUI的三大特性,同時提到了ArkUI是一套用于構(gòu)建HarmonyOS應(yīng)用界面的UI開發(fā)框架,本期我們將從架構(gòu)設(shè)計上來聊聊ArkUI的設(shè)計理念。

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

ArkUI架構(gòu)圖

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

ArkUI框架的“前驅(qū)”——【前端層】

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

前端層

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

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

獨立的封裝

此外,ArkUI對常用的UI組件的結(jié)構(gòu)、樣式、事件三大屬性進行了獨立的封裝,內(nèi)置于SDK中。開發(fā)人員可以根據(jù)項目設(shè)計需求,調(diào)用與設(shè)計匹配的組件函數(shù),傳入相應(yīng)的參數(shù)來完成UI描述。

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

聲明式UI信息語法

同時使用聲明式UI信息語法,可以讓數(shù)據(jù)和View進行聯(lián)動更新,華為自研語言ArkTS為這種聯(lián)動刷新提供了多維度的狀態(tài)管理機制,開發(fā)人員通過對數(shù)據(jù)進行注釋標(biāo)記,合理控制數(shù)據(jù)對應(yīng)View的更新作用范圍。

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

三種更新方式

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

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

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

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

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

核心層

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

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

方舟編譯運行時

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

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

運行流程圖

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

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

跨語言調(diào)用

第1步是跨語言調(diào)用

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

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

新語言ArkTS

而在ArkUI支持的多種語言中,ArkTS是以TS為語法基礎(chǔ)的應(yīng)用編程語言。

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

類型系統(tǒng)

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

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

統(tǒng)一字節(jié)碼

第2步是統(tǒng)一字節(jié)碼

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

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

統(tǒng)一字節(jié)碼

第3步是機器碼和安裝包

字節(jié)碼在設(shè)備上可以通過解釋執(zhí)行或者編譯后執(zhí)行的方式運行,對于執(zhí)行性能要求高的部分字節(jié)碼調(diào)用AOT生成機器碼。

最后,應(yīng)用經(jīng)歷了開發(fā)、字節(jié)碼預(yù)編譯、AOT靜態(tài)優(yōu)化編譯、打包簽名就形成了一個完整安裝包,這樣一來就終于可以在設(shè)備上運行預(yù)覽了。

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

GC機制

第4步是GC(Garbage Collection)機制

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

搭載HarmonyOS系統(tǒng)的設(shè)備

對比其他設(shè)備,搭載HarmonyOS系統(tǒng)的設(shè)備上運行應(yīng)用時會顯得特別流暢,這里的秘密是什么呢?

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

GC機制技術(shù)問題

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

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

STW

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

STW暫停時間較長

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

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

HPP GC

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

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

HPP GC

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

它在HarmonyOS系統(tǒng)終端運行時,由C++編寫UI的基本組件、布局、動效和事件組成。供UI前端開發(fā)人員調(diào)用。

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

渲染管線

渲染管線是位于運行時內(nèi)部的一個獨立的渲染線程,它負責(zé)支配CPU多線程地去工作,讓CPU為GPU提供更多的渲染數(shù)據(jù),最大額度的調(diào)取GPU的能力。

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

通過本期ArkUI架構(gòu)的學(xué)習(xí),相信大家已經(jīng)了解方舟編譯運行時的技術(shù)和流程,也對ArkUI的設(shè)計理念有了基礎(chǔ)的認識。完整版的內(nèi)容可查看上方的視頻,我們下期再見~

END

想了解更多HarmonyOS技術(shù)?

后臺留言給我們

立刻安排!


原文標(biāo)題:ArkUI,更高效的框架設(shè)計

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


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

    關(guān)注

    80

    文章

    2118

    瀏覽量

    32820

原文標(biāo)題:ArkUI,更高效的框架設(shè)計

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

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

掃碼添加小助手

加入工程師交流群

    評論

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

    【HarmonyOS next】ArkUI-X新聞熱搜聚合App【進階】

    API,展示了多平臺榜單數(shù)據(jù)并支持網(wǎng)頁詳情查看。項目采用ArkUI框架開發(fā),現(xiàn)通過ArkUI-X實現(xiàn)iOS平臺的無縫遷移。 1.2 核心技術(shù)棧 HarmonyOS:原生開發(fā)平臺 ArkUI
    發(fā)表于 06-28 21:43

    【HarmonyOS next】ArkUI-X休閑益智兒童拼圖【進階】

    一、前言:當(dāng)拼圖遇上跨端開發(fā) 最近在開發(fā)一款跨平臺的兒童拼圖游戲時,我深刻體會到了ArkUI-X框架的威力——同一套代碼竟能同時在華為Mate60 Pro和iPhone15上流暢運行!這不僅節(jié)省
    發(fā)表于 06-28 21:41

    【HarmonyOS next】ArkUI-X休閑益智猜字謎【基礎(chǔ)】

    下圖是在iOS中的運行效果 下圖是在HarmonyOS中的運行效果 今天咱們來聊聊如何用ArkUI-X這個新興框架實現(xiàn)跨端開發(fā),通過一個猜字謎小游戲帶大家感受它的開發(fā)魅力。本文不僅能讓你看到
    發(fā)表于 06-26 20:01

    ArkUI-X通過Stage模型開發(fā)Android端應(yīng)用指南(一)

    簡介 本文介紹將ArkUI框架擴展到Android平臺所需要的必要的類及其使用說明,開發(fā)者基于OpenHarmony,可復(fù)用大部分的應(yīng)用代碼(生命周期等)并可以部署到Android平臺,降低跨平臺
    發(fā)表于 06-24 22:16

    ArkUI介紹

    ArkUI(方舟UI框架)為應(yīng)用的UI開發(fā)提供了完整的基礎(chǔ)設(shè)施,包括簡潔的UI語法、豐富的UI功能(組件、布局、動畫以及交互事件),以及實時界面預(yù)覽工具等,可以支持開發(fā)者進行可視化界面開發(fā)
    發(fā)表于 06-24 06:41

    ArkUI-X案例解析

    != undefined) { this.backDisplaySyncSlow?.stop(); } } } 由于當(dāng)前ArkUI-X框架未適配這套方法,在arkui-x側(cè)實際上使用了
    發(fā)表于 06-23 22:40

    HarmonyOS NEXT應(yīng)用元服務(wù)布局優(yōu)化ArkUI框架執(zhí)行流程

    一、 ArkUI框架執(zhí)行流程 在使用ArkUI開發(fā)中,我們通過布局組件和基礎(chǔ)組件進行界面描述,這些描述會呈現(xiàn)出一個組件樹的結(jié)構(gòu),基礎(chǔ)組件在其中為葉子結(jié)點,布局組件則是中間節(jié)點,可以把這棵樹稱之為
    發(fā)表于 06-23 09:41

    ArkUI-X應(yīng)用工程結(jié)構(gòu)說明

    簡介 本文檔配套ArkUI-X,將OpenHarmony ArkUI開發(fā)框架擴展到不同的OS平臺,比如Android和iOS平臺,讓開發(fā)者基于ArkUI,可復(fù)用大部分的應(yīng)用代碼(UI以
    發(fā)表于 06-19 23:11

    ArkUI-X跨平臺應(yīng)用改造指南

    工作量大幅增加,開發(fā)成本也隨之上升,而且很難保持一致的交互體驗。 ArkUI-X 跨平臺框架是基于 HarmonyOS 打造的跨端跨平臺框架,能實現(xiàn) “一次開發(fā)、三平臺部署”。 基于ArkTS開發(fā)
    發(fā)表于 06-16 23:05

    ArkUI-X在Android平臺動態(tài)化開發(fā)指南

    本文介紹如何在Android平臺進行ArkUI-X動態(tài)化開發(fā),包括動態(tài)化目錄規(guī)則及約束。 適用場景 動態(tài)化主要包括兩個典型場景: 場景1:框架動態(tài)化,為了降低應(yīng)用ROM體積占用,及滿足動態(tài)升級框架
    發(fā)表于 06-15 23:33

    ArkUI-X框架LogInterface使用指南

    ArkUI-X框架支持日志攔截能力,Android側(cè)提供原生接口,用于注入LogInterface接口,框架日志及ts日志通過該接口輸出,本文的核心內(nèi)容是介紹如何在Android平臺上有效利用
    發(fā)表于 06-15 23:20

    ArkUI-X與Android消息通信

    平臺橋接用于客戶端(ArkUI)和平臺(Android或iOS)之間傳遞消息,即用于ArkUI與平臺雙向數(shù)據(jù)傳遞、ArkUI側(cè)調(diào)用平臺的方法、平臺調(diào)用ArkUI側(cè)的方法。本文主要介紹A
    發(fā)表于 06-08 22:15

    ArkUI-X跨平臺框架接入指南

    ArkUI跨平臺框架(ArkUI-X)進一步將ArkUI開發(fā)框架擴展到了多個OS平臺:目前支持OpenHarmony、Android、 iO
    發(fā)表于 05-18 18:21

    華為推出RN/H5多設(shè)備自適應(yīng)組件庫

    存在大量用跨平臺框架開發(fā)的應(yīng)用,部分頁面采用React Native(RN)和H5等框架開發(fā),這些框架在系統(tǒng)級的多設(shè)備適配能力上相對有限,導(dǎo)致在折疊機、平板等設(shè)備上的適配效率不如ArkUI
    的頭像 發(fā)表于 01-16 14:46 ?752次閱讀

    GaN如何實現(xiàn)更高效、更緊湊的電源

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