成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

OpenHarmony ArkUI - ets_runtime啟動流程源碼解讀

系統 OpenHarmony
本文基于OpenHarmony源碼梳理應用的啟動過程,介紹Appspawn/ability_runtime/ace_engine/ets_runtime等重要模塊的初始化流程,以及它們之間的相互關系。

??想了解更多關于開源的內容,請訪問:??

??51CTO 開源基礎軟件社區??

??https://ost.51cto.com??

前言

本文基于OpenHarmony源碼梳理應用的啟動過程,介紹appspawn/ability_runtime/ace_engine/ets_runtime等重要模塊的初始化流程,以及它們之間的相互關系。

不同形態的hap應用在具體細節上會有一些差異,但整體的流程上是一致的。本文基于OpenHarmoney 3.2標準系統 FA模式的ets應用進行闡述。

1、應用啟動整體流程

查看各個進程的父子關系可知,OpenHarmony的系統應用和用戶應用進程,都是由應用孵化器(appspawn)拉起的。

OpenHarmony ArkUI - ets_runtime啟動流程源碼解讀-開源基礎軟件社區

應用啟動的整理流程如下圖所示:

OpenHarmony ArkUI - ets_runtime啟動流程源碼解讀-開源基礎軟件社區

說明: 應用啟動時,appspawn進程會fork出一個應用子進程,創建AceAbility實現類和AceContainer。AceContainer初始化過程中會在JS線程中創建JS運行環境,包括JsEngine、NativeEngin、ArkJSRuntime、JSThread、EcmaVM等重要組件。

2、啟動流程詳解

(1)appspawn 創建應用進程

OpenHarmony ArkUI - ets_runtime啟動流程源碼解讀-開源基礎軟件社區

應用日志:

08-05 17:58:11.955 255-255/appspawn I C02c11/APPSPAWN: [appspawn_service.c:408]child process com.example.myapplication success pid 2345

關鍵代碼流程:

// base\startup\appspawn\standard\appspawn_service.c
APPSPAWN_STATIC void OnReceiveRequest(const TaskHandle taskHandle, const uint8_t *buffer, uint32_t buffLen)
AppSpawnProcessMsg(sandboxArg, &appProperty->pid);
// base/startup/appspawn/common/appspawn_server.c
int AppSpawnProcessMsg(AppSandboxArg *sandbox, pid_t *childPid)
if (client->cloneFlags & CLONE_NEWPID) {
pid = clone(AppSpawnChild, childStack + SANDBOX_STACK_SIZE, client->cloneFlags | SIGCHLD, (void *)sandbox);
pid = fork(); // fork出應用進程
*childPid = pid;
if (pid == 0) { // 子進程流程執行
AppSpawnChild((void *)sandbox);
int AppSpawnChild(void *arg)
struct AppSpawnContent_ *content = sandbox->content;
DoStartApp(content, client, content->longProcName, content->longProcNameLen);
// notify success to father process and start app process
NotifyResToParent(content, client, 0);
content->runChildProcessor(content, client); // 進入應用主線程 (ability_runtime 的 MainThread)
}

(2)應用主線程初始化Ability

OpenHarmony ArkUI - ets_runtime啟動流程源碼解讀-開源基礎軟件社區

應用的整體狀態流轉是由Ability實例對象來控制完成的。因此應用進程拉起時,會先創建出Ability。不同的應用模型在這里會創建不同的實例類型:

// foundation\ability\ability_runtime\frameworks\native\ability\native\ability_impl_factory.cpp
// AbilityImplFactory::MakeAbilityImplObject() 方法:
switch (info->type) {
case AppExecFwk::AbilityType::PAGE:
if (info->isStageBasedModel) {
abilityImpl = std::make_shared<NewAbilityImpl>();
} else {
abilityImpl = std::make_shared<PageAbilityImpl>();
}
break;
case AppExecFwk::AbilityType::SERVICE:
abilityImpl = std::make_shared<ServiceAbilityImpl>();
break;
case AppExecFwk::AbilityType::DATA:
abilityImpl = std::make_shared<DataAbilityImpl>();
break;

AbilityImpl實例創建后,應用開始進入Start狀態,觸發AceAbility::OnStart()回調。在該回調中,會創建JS運行環境。

(3)AceContainer初始化

AceContainer初始化可分為兩個階段:

第一個階段創建JS運行時環境(js_engine, native_engine, ets_runtime);

第二個階段調度js_engine開始讀取js字節碼文件(xxx.abc)

階段一:創建JS運行時環境

OpenHarmony ArkUI - ets_runtime啟動流程源碼解讀-開源基礎軟件社區

這里的代碼流程比較長… 具體調用過程見上圖說明。講幾個主要的點:

  1. AceContianer初始化時會創建一個任務執行線程 FlutterTaskExecutor,這就是后續js代碼的執行線程。 應用主線程把需要在js線程中執行的代碼包裝成task,放到FlutterTaskExecutor中去執行。
  2. 創建Js引擎時可以選擇不同的引擎類型,這是在源碼編譯階段由宏開關控制的。
    \foundation\arkui\ace_engine\frameworks\bridge\declarative_frontend\engine\declarative_engine_loader.cpp
RefPtr<JsEngine> DeclarativeEngineLoader::CreateJsEngine(int32_t instanceId) const
{
#ifdef USE_V8_ENGINE
return AceType::MakeRefPtr<V8DeclarativeEngine>(instanceId);
#endif

#ifdef USE_QUICKJS_ENGINE
return AceType::MakeRefPtr<QJSDeclarativeEngine>(instanceId);
#endif

#ifdef USE_ARK_ENGINE
return AceType::MakeRefPtr<JsiDeclarativeEngine>(instanceId);
#endif
}

宏開關在如下配置文件中定義:

foundation/arkui/ace_engine/adapter/ohos/build/config.gni。

engine_defines = [ "USE_ARK_ENGINE" ]
  1. ArkNativeEngine初始化時創建了NAPI層的各個重要組件(moduleManager, scopeManager, referenceManager, loop…)
  2. ArkNativeEngine向js運行環境中注冊了一個"requireNapi()"方法,該方法是js應用import各種NAPI庫的入口。
    js代碼中的"import xxxx"在hap包編譯階段會改寫為“requireNapi(xxx)”,當這行代碼被js引擎解釋執行時,即會調用到 ArkNativeEngine 中注冊的requireNapi c++實現代碼,通過NAPI的ModuleManager 模塊完成 xxxNAPI模塊lib庫的加載。

階段二:讀取并執行js字節碼文件

OpenHarmony ArkUI - ets_runtime啟動流程源碼解讀-開源基礎軟件社區

在 AceContainer::RunPage() 流程中,會依次創建兩個js線程的task, 分別讀取 app.abc和index.abc文件。

細節1: JsiDeclarativeEngine::LoadJs()方法中是根據傳入的*.js文件名去讀取對應的*.abc

// foundation\arkui\ace_engine\frameworks\bridge\declarative_frontend\engine\jsi\jsi_declarative_engine.cpp
void JsiDeclarativeEngine::LoadJs(const std::string& url, const RefPtr<JsAcePage>& page, bool isMainPage)
...
const char js_ext[] = ".js";
const char bin_ext[] = ".abc";
auto pos = url.rfind(js_ext);
std::string urlName = url.substr(0, pos) + bin_ext; // 將文件名 xxx.js 替換成 xxx.abc

細節2:EcmaVM::InvokeEcmaEntrypoint() 方法中會執行index.abc中的入口函數func_main_0, 該函數在原始的index.js文件中并沒有,是hap包編譯后生成在index.abc文件中的。

??想了解更多關于開源的內容,請訪問:??

??51CTO 開源基礎軟件社區??

??https://ost.51cto.com??

責任編輯:jianghua 來源: 51CTO 開源基礎軟件社區
相關推薦

2022-08-12 19:13:07

etswifi連接操作

2022-05-26 14:50:15

ArkUITS擴展

2022-02-23 15:07:22

HarmonyOS常用控制ArkUI-eTS

2022-09-16 15:34:32

CanvasArkUI

2022-05-20 10:56:54

AbilityeTS FA調用

2022-07-12 17:03:43

鴻蒙網絡請求庫

2024-01-11 15:54:55

eTS語言TypeScript應用開發

2022-02-23 15:36:46

ArkUI-eTS事件監聽鴻蒙

2022-01-25 17:05:44

ArkUI_eTS操作系統鴻蒙

2023-08-17 15:01:08

ArkUI布局渲染

2022-07-20 15:32:25

時鐘翻頁Text組件

2022-07-04 16:34:46

流光按鈕Stack

2022-11-02 16:06:54

ArkUIETS

2022-10-24 14:49:54

ArkUI心電圖組件

2021-10-15 10:26:28

鴻蒙HarmonyOS應用

2022-08-29 17:34:05

鴻蒙操作系統

2022-09-05 15:22:27

ArkUIets

2022-03-07 15:22:16

classHarmony鴻蒙

2021-07-26 11:07:34

主循環Cocos Creat源碼

2022-06-07 10:33:29

Camera組件鴻蒙
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 暖暖成人免费视频 | 色综合久| 久久精品久久久久久 | 中文字幕一区二区三区在线观看 | 做a的各种视频 | 国产影音先锋 | 久久久蜜桃 | 日韩成人免费视频 | 亚洲欧洲精品成人久久奇米网 | 亚洲视频在线免费观看 | 天天天天操 | 国产成人av在线播放 | 日韩中文字幕在线观看 | 精品99久久 | 久久久久国产一区二区三区 | 孰女乱色一区二区三区 | 国产高清精品在线 | 日韩高清国产一区在线 | 日本电影免费完整观看 | 久久99精品久久久久久秒播九色 | 午夜a v电影 | 777777777亚洲妇女| 欧美色综合 | 91精品国产色综合久久不卡蜜臀 | 欧洲尺码日本国产精品 | 精品99久久 | 81精品国产乱码久久久久久 | 午夜视频一区二区三区 | 国产在线一 | 一级毛片免费看 | 久久综合九色综合欧美狠狠 | 欧美精品在线一区二区三区 | 日本一区二区影视 | 一区二区三区观看视频 | 久久国产精品99久久久久 | 久久久精 | 国产精品免费一区二区三区四区 | 91国内外精品自在线播放 | 国产在线视频一区二区董小宛性色 | 亚洲人久久 | 久久久久久久久99 |