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

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

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

3天內不再提示

HarmonyOS JS應用開發需要關注哪些線程?官方解析來啦~

話說科技 ? 來源:話說科技 ? 作者:話說科技 ? 2021-09-06 15:25 ? 次閱讀

作者:wuyawei,華為軟件開發工程師

HarmonyOS 2提供了對兩種開發語言的支持:Java和JavaScript(下文簡稱JS)。從事過Android開發的同學對Java都很熟悉了,其多線程特性能夠讓多任務并行執行,充分利用硬件資源開發出高性能的應用。在HarmonyOS 2上,JS目前無法像Java一樣直接創建新的Thread,那么使用JS語言開發HarmonyOS應用是否會遇到硬件資源無法充分利用的情況呢?

雖然使用JS語言目前無法直接創建新的Thread,但是HarmonyOS的JS UI框架提供了多線程的宿主環境,可以幫助應用開發豐富的業務邏輯。在開發HarmonyOS 2應用時,開發者除了需要了解JS線程外,還需要關注哪些線程?這些線程之間的關系又是什么樣的?下面讓我們一起來研究一下。

一、HarmonyOS的JS UI框架

HarmonyOS的JS UI框架包括應用層(Application)、前端框架層(Framework)、引擎層(Engine)和平臺適配層(Porting Layer),如下圖所示:

HarmonyOS JS應用開發需要關注哪些線程?官方解析來啦

  • Application

應用層表示開發者使用JS UI框架開發的FA應用,這里的FA應用特指JS FA應用。https://developer.harmonyos.com/cn/docs/documentation/doc-guides/ui-js-fa-developing-0000001063300612

  • Framework

前端框架層主要完成前端頁面解析,以及提供MVVM(Model-View-ViewModel)開發模式、頁面路由機制和自定義組件等能力。

  • Engine

引擎層主要提供動畫解析、DOM(Document Object Model)樹構建、布局計算、渲染命令構建與繪制、事件管理等能力。

  • Porting Layer

適配層主要完成對平臺層進行抽象,提供抽象接口,可以對接到系統平臺。比如:事件對接、渲染管線對接和系統生命周期對接等。

二、JS UI框架的線程模型

每個HarmonyOS JS應用,都是通過JS UI框架進行加載渲染的。HarmonyOS的JS UI框架包含了JS線程、UI線程、GPU線程、IO線程這4個線程,并且在JS UI框架外還會存在一類后臺任務線程。

其中GPU線程與IO線程主要是JS UI框架初始化與頁面加載渲染的過程需要的,為JS UI框架內部的專有線程,不會被應用直接操作到,應用不需要特別關注;UI線程、JS線程和后臺任務線程會與應用開發代碼相關,后面著重分析這三個線程的作用和關系。

  • UI線程:負責應用界面的繪制刷新,與應用的進程號相同,又叫主線程。如果開發JS+JAVA的混合編程(https://developer.harmonyos.com/cn/docs/documentation/doc-references/js-apis-fa-calls-pa-mechanism-0000001050022401),需要特別注意的是JAVA PA(Particle Ability)的onStart/onConnect等Ability生命周期回調便是運行在主線程,若在這些聲明周期回調上執行耗時操作則會導致JS UI的繪制刷新卡住。

  • JS線程:應用的JS代碼會被JS引擎解析執行,并運行在JS線程上,目前我們工程中看到的所有的JS代碼都會執行在這個進程下唯一的JS線程上。

  • 后臺任務線程:這是對JS UI框架外部的后臺線程的一個統稱,并不單指一個線程,也并不唯一。它包含了Java PA中onRemoteRequest()業務邏輯的執行線程、文件操作API、網絡訪問API內部實現等相關線程。

下面我們結合測試代碼的來看一下這3個應用開發需要關注的線程之間的關系。

三、JS線程與UI線程的關系

為了驗證JS線程與UI線程的關系,我們準備了一個實驗性質的Demo,主要代碼以及運行過程的Log如下:

首先我們在IDE建立一個Empty Ability(JS)模板的HelloWorld工程,在生命周期、按鈕響應回調方法里增加Log以觀察線程情況。剛創建的app.js中Application生命周期默認已經有Log,無需額外添加。

我們需要在自動創建的MainAbility.java中onStart/onTouchEvent回調函數增加HiLog打印:

HiLog.info(LABEL_LOG, "MainAbility::onStart");

HiLog.info(LABEL_LOG, "MainAbility::onTouchEvent");

我們只需要在主界面index.js文件中onInit增加日志:

CoffeeScript

console.info('page.default onInit');

然后在index.hml中增加一個button以及會一直進行動畫的progress組件:

I'm a button

最后在index.js中增加按鈕點擊響應事件以及Log,并且嘗試sleep阻塞js線程:

function sleep(delay) {

for (var t = Date.now(); Date.now() - t <= delay; );

}

onButtonClick() {

console.info('onButtonClick begin');

sleep(1000);

console.info('onButtonClick end');

}

我們將應用運行起來,點擊一次按鈕,會發現progress組件動畫并不會因為onButtonClick阻塞了1秒鐘而有任何暫停,我們一起來分析一下這個過程中的Log:

15:30:07.323 15870-15870/com.blancwu.test I 01100/MainAbility: MainAbility::onStart

15:30:07.342 15870-18938/com.blancwu.test I 03B00/JSApp: app Log: AceApplication onCreate

15:30:07.352 15870-18938/com.blancwu.test I 03B00/JSApp: app Log: page.default onInit

15:30:31.006 15870-15870/com.blancwu.test I 01100/MainAbility: MainAbility::onTouchEvent

15:30:31.041 15870-15870/com.blancwu.test I 01100/MainAbility: MainAbility::onTouchEvent

15:30:31.104 15870-15870/com.blancwu.test I 01100/MainAbility: MainAbility::onTouchEvent

15:30:31.106 15870-15870/com.blancwu.test I 01100/MainAbility: MainAbility::onTouchEvent

15:30:31.112 15870-18938/com.blancwu.test I 03B00/JSApp: app Log: onButtonClick begin

15:30:32.113 15870-18938/com.blancwu.test I 03B00/JSApp: app Log: onButtonClick end

從輸出的Log中,時間點后面跟著的便是我們執行日志的代碼行所在的進程號與線程號,剛才我們增加的日志均在15870這個進程下,這個進程下又存在15870線程以及18938線程。其中15870與進程號相同,這便是我們說的UI線程;我們在.js文件中增加的日志全都會在18938線程上打印出來,這個便是JS線程。

HarmonyOS JS應用開發需要關注哪些線程?官方解析來啦

在應用初始化時,首先進入MainAbility.java的onStart生命周期回調,然后才進入AceApplication、Page等JS代碼邏輯;應用初始化完畢后,UI線程上便會持續刷新progress組件的動畫,當用戶點擊按鈕觸發onButtonClick阻塞1秒時,因為阻塞的僅僅是JS線程,所以UI線程上progress組件的動畫刷新并不會有任何影響,還是在持續刷新。所以我們可以確定JS線程與UI線程的相互調用應該是通過某種消息機制完成的,而不是阻塞式的調用。

四、JS線程與后臺任務線程的關系

JS UI框架提供了JS FA(Feature Ability)調用Java PA(Particle Ability)的機制,該機制提供了一種通道來傳遞方法調用、處理數據返回以及訂閱事件上報的機制,Java PA運行在一個獨立的后臺任務線程,可以支撐應用開發多線程的業務邏輯。我們同樣制作一個Demo來驗證JS線程與Java PA線程的關系:

在上一個Demo基礎上,我們修改onButtonClick的JS代碼,通過FeatureAbility.callAbility拉起并調用了名為一個類名為ServiceAbility的Java PA,并拿到返回結果:

var action = {};

action.bundleName = 'com.blancwu.test';

action.abilityName = 'com.blancwu.test.ServiceAbility';

action.messageCode = 1001;

action.abilityType = 0;

action.syncOption = 0;

console.info('FeatureAbility.callAbility begin' + JSON.stringify(action));

FeatureAbility.callAbility(action).then(function (value) {

console.info('FeatureAbility.callAbility async result ' + JSON.stringify(value));

})

console.info('FeatureAbility.callAbility end' + JSON.stringify(action));

在ServiceAbility的onRemoteRequest中增加Log輸出,并sleep 1秒種,以便觀察線程情況與之間關系:

@Override

public boolean onRemoteRequest(int code, MessageParcel data, MessageParcel reply, MessageOption option) throws RemoteException {

HiLog.info(LABEL_LOG, "onRemoteRequest begin " + code);

if (code == 1001) {

try {

Thread.sleep(1000);

} catch (InterruptedException e) {

e.printStackTrace();

}

Map result = new HashMap();,>,>

result.put("result", 1);

reply.writeString(ZSONObject.toZSONString(result));

}

HiLog.info(LABEL_LOG, "onRemoteRequest end " + code);

return super.onRemoteRequest(code, data, reply, option);

}

以上代碼完成后,我們進行執行,progress組件的動畫同樣不會被打斷,得到的Log如下:

06-25 13:31:48.090 4133-5887/com.blancwu.test I 03B00/JSApp: app Log: FeatureAbility.callAbility begin{"bundleName":"com.blancwu.test","abilityName":"com.blancwu.test.ServiceAbility","messageCode":1001,"abilityType":0,"syncOption":0}

06-25 13:31:48.094 4133-5887/com.blancwu.test I 03B00/JSApp: app Log: FeatureAbility.callAbility end{"bundleName":"com.blancwu.test","abilityName":"com.blancwu.test.ServiceAbility","messageCode":1001,"abilityType":0,"syncOption":0}

06-25 13:31:48.112 4133-4133/com.blancwu.test E 01100/ServiceAbility: [8187916a4418bed, 399b373, f521b3] ServiceAbility::onStart

06-25 13:31:48.126 4133-5837/com.blancwu.test I 01100/ServiceAbility: [8187916a4418bed, 171378f, 385abb1] onRemoteRequest begin 1079135572

06-25 13:31:48.126 4133-5837/com.blancwu.test I 01100/ServiceAbility: [8187916a4418bed, 171378f, 385abb1] onRemoteRequest end 1079135572

06-25 13:31:48.126 4133-5837/com.blancwu.test I 00000/RemoteObject: [8187916a4418bed, 171378f, 385abb1] Java onRemoteRequest called

06-25 13:31:48.143 4133-5837/com.blancwu.test I 01100/ServiceAbility: onRemoteRequest begin 1001

06-25 13:31:49.145 4133-5837/com.blancwu.test I 01100/ServiceAbility: onRemoteRequest end 1001

06-25 13:31:49.145 4133-5837/com.blancwu.test I 00000/RemoteObject: Java onRemoteRequest called

06-25 13:31:49.151 4133-5887/com.blancwu.test I 03B00/JSApp: app Log: FeatureAbility.callAbility async result "{"result":1}"

整個執行過程可以描述如下圖:

HarmonyOS JS應用開發需要關注哪些線程?官方解析來啦

我們觀察到本次運行主進程(UI線程)號為4133,JS代碼執行在JS線程(5887),Java PA響應onRemoteRequest執行在另一個后臺任務線程(5837)。通過Log我們看到onRemoteRequst即使阻塞了后臺任務線程1s也不會影響JS線程的執行以及主線程(UI線程)上動畫的刷新,做到了JS線程與后臺任務線程上的任務并行處理。

五、JS的異步機制

上面從代碼實驗角度觀察到了應用開發中JS線程與其他線程的關系,那么JS線程是怎么與其他線程進行異步通信的呢?我們先來看一下傳統的瀏覽器環境下的機制:

HarmonyOS JS應用開發需要關注哪些線程?官方解析來啦

上圖中,JS線程中的函數調用會存在于棧(stack)中,棧中的函數可以調用瀏覽器環境提供的WebAPIs,包含了DOM、ajax、timeout等API,這些API會在瀏覽器環境提供的另外一個外部線程執行,執行完成后會在任務隊列(callback queue)中加入對應的回調事件(如onClick、onLoad、onDone)。當棧中的代碼執行完畢,即棧清空后,JS線程又會通過event loop取出任務隊列中的下一個任務進行執行,以此類推完成整個的程序執行。更具體的機制可以去看阮一峰老師介紹JS EventLoop的文章。

JS EventLoop的介紹

http://www.ruanyifeng.com/blog/2014/10/event-loop.html

HarmonyOS的JS UI框架同樣遵循上述最基本的EventLoop調度機制,并且提供了更多的機制和API,讓業務邏輯可以在外部線程執行;包括上面提到的Java PA機制以及還未提及的支持異步回調的系統能力API。其中,支持異步回調的系統能力API包含文件系統操作和網絡操作等,感興趣的同學可以按照我們實驗Demo類似的方法去嘗試一下。

● 文件系統操作API參考

https://developer.harmonyos.com/cn/docs/documentation/doc-references/js-apis-file-storage-0000000000629445

六、未來展望

目前HarmonyOS的JS應用內實現多線程的最佳方式是通過混合編程調用Java PA方式,但無法支持純JS應用開發多線程業務,純JS應用目前僅可使用框架提供的異步API了,那么這些異步API能解決各種復雜場景的問題嗎?

JS線程加上異步API能夠很好解決單個I/O阻塞的問題,但是如果遇到大量的I/O事件,比如批刪除大量文件,通過for循環發起了大量異步任務,也會降低執行效率,甚至阻塞其他異步任務的執行。并且如果要使用JS語言開發計算密集型的任務,也無法在唯一的JS線程上進行。

這時就需要一個真正的JS多線程處理機制了,雖然目前HarmonyOS 2還未支持,但未來HarmonyOS會考慮規劃出與HTML5類似提供支持WebWorker機制,支持開發出多線程的JS代碼,提供給應用開發者更多的發揮空間。

fqj

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

    關注

    0

    文章

    507

    瀏覽量

    20104
  • HarmonyOS
    +關注

    關注

    80

    文章

    2084

    瀏覽量

    32245
收藏 人收藏

    評論

    相關推薦
    熱點推薦

    鴻蒙5開發寶藏案例分享---Web開發優化案例分享

    開發者需關注API更新或在設計預加載策略時利用此特性。 預下載 (Pre-Fetch/DownLoad) 痛點: 頁面里的圖片、CSS、JS等資源,邊下載邊解析渲染,遇到大文件或慢
    發表于 06-12 17:20

    鴻蒙5開發寶藏案例分享---Web加載時延優化解析

    當然可以!下面是一篇詳細、易懂的文章,結合鴻蒙官方案例和實際代碼,幫你深入理解Web加載完成時延的優化技巧? ?** 鴻蒙開發寶藏:Web加載完成時延優化實戰** 大家好呀!今天在翻鴻蒙開發者文檔
    發表于 06-12 17:11

    鴻蒙5開發寶藏案例分享---應用并發設計

    ?** 鴻蒙并發編程實戰指南:解鎖ArkTS多線程黑科技** 嘿,開發者朋友們! 今天給大家扒一扒鴻蒙官方文檔里藏著的并發編程寶藏—— 100+實戰場景解決方案 !從金融理財到游戲開發
    發表于 06-12 16:19

    HarmonyOS5云服務技術分享--ArkTS開發函數

    ) 最后說句掏心窩的話:本地調試真的能省下80%的打包等待時間,早用早輕松!開發過程中遇到任何問題,歡迎在評論區拍磚交流~ ? 祝各位開發者調試順利,BUG退散!下次咱們再聊聊云函數的高階玩法,記得關注哦~ ? (本文檔基于
    發表于 05-22 17:29

    HarmonyOS5云服務技術分享--ArkTS開發Node環境

    ? 你好呀,開發者小伙伴們!今天我們來聊聊如何在HarmonyOS(ArkTS API 9及以上)中玩轉云函數,特別是結合Node.js和HTTP觸發器的開發技巧。文章會手把手帶你從零
    發表于 05-22 17:21

    OpenHarmony應用開發精品課程第七期來啦

    OpenHarmony應用開發精品課程第七期來啦
    的頭像 發表于 04-15 14:15 ?157次閱讀
    OpenHarmony應用<b class='flag-5'>開發</b>精品課程第七期<b class='flag-5'>來啦</b>

    HarmonyOS NEXT 原生應用/元服務-ArkTS代碼調試worker/taskpool調試

    代碼中設置斷點。 啟動調試,當代碼中斷點命中時,調試窗口會新啟動一個調試會話,顯示 taskpool 線程的堆棧信息。 本文主要參考與引用自HarmonyOS官方文檔。
    發表于 03-13 17:46

    HarmonyOS NEXT 原生應用/元服務調試概述

    一、概述 DevEco Studio提供了豐富的HarmonyOS應用/元服務調試能力,支持JS、ArkTS、C/C單語言調試和ArkTS/JS+C/C跨語言調試能力,并且支持三方庫源碼調試,幫助
    發表于 02-26 11:03

    HarmonyOS第一課》煥新升級,賦能開發者快速掌握鴻蒙應用開發

    注重理論與實踐的結合,提供讓開發者快速上手的codelab編程練習,開發者能在實戰中鞏固所學,系統掌握核心開發技能。完成課程后,開發者可參加官方
    發表于 01-02 14:24

    HarmonyOS開發指導類文檔更新速遞(下)

    伴隨著HarmonyOS 5.0.0 Release、HarmonyOS 5.0.1 Release版本的發布,HarmonyOS官網文檔也帶來了不少上新內容。本期HarmonyOS
    的頭像 發表于 12-30 09:54 ?1013次閱讀
    <b class='flag-5'>HarmonyOS</b><b class='flag-5'>開發</b>指導類文檔更新速遞(下)

    HarmonyOS Web開發性能優化指導

    體驗。 預渲染:預渲染指在后臺對需要加載的頁面進行預先渲染,提前完成整個頁面加載的流程。當用戶需要訪問該頁面時,可以直接切換至前臺展示,實現頁面“秒開”的效果。預渲染要求在進行DOM解析
    發表于 12-06 08:41

    今晚直播!OpenHarmony應用開發精品課程第二期來啦~

    原文標題:今晚直播!OpenHarmony應用開發精品課程第二期來啦
    的頭像 發表于 11-20 15:24 ?452次閱讀

    鴻蒙跨端實踐-JS虛擬機架構實現

    類似的框架,我們需要自行實現以確保核心基礎能力的完整。 鴻蒙虛擬機的開發經歷了從最初 ArkTs2V8 到 JSVM + Roma新架構方案 。在此過程中,我們實現了完整的鴻蒙版的“J2V8”和 基于系統JSVM的JS虛擬機框架
    的頭像 發表于 09-30 14:42 ?2901次閱讀
    鴻蒙跨端實踐-<b class='flag-5'>JS</b>虛擬機架構實現

    推薦一個支持js的嵌入式設備開發平臺

    可以通過vscode開發js,實時推送js代碼到設備里運行,無需編譯,支持屏幕,感興趣的可以看看 https://github.com/duoxianwulian/dxdop 提供很多js
    發表于 09-04 14:04

    ESP32雙核系列基于FreeRTOS編程,需不需要關注雙核特性呢?

    如題,我需不需要關注兩個cpu都有在工作,運行線程
    發表于 06-19 07:32
    主站蜘蛛池模板: 欧美午夜在线观看 | 444kk免费| 五月婷婷六月丁香综合 | 丁香六月 久久久 | 全免费午夜一级毛片真人 | 视频在线观看一区二区三区 | 久久精品视频7 | free性欧美高清另类 | 五月婷婷六月综合 | 国产成人一区二区三中文 | 国产福利vr专区精品 | avtt亚洲一区中文字幕 | www.色亚洲| 4455永久在线毛片观看 | 日本小视频免费 | 天堂在线网 | 四虎永久在线精品免费影视 | 黄网免费看 | 五月欧美 | 色偷偷资源网 | 免费h视频 | 丁香综合激情 | 免费一级毛片私人影院a行 免费一级毛片无毒不卡 | 狠狠色婷婷七月色综合 | 一级特一级特色生活片 | av免费网站在线观看 | 亚洲国产成人久久精品影视 | 成人国产在线24小时播放视频 | 中文字幕一二三区乱码老 | 一级毛片在线不卡直接观看 | a级毛毛片看久久 | 色多多在线播放 | 天天射天天搞 | 亚洲永久网站 | 色欧美亚洲 | 一级视频在线观看免费 | 最新亚洲人成网站在线影院 | 天堂中文在线资源 | 日不卡 | 亚洲国产成人精品久久 | 亚洲免费一级视频 |