国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

《HarmonyOS開(kāi)發(fā) – OpenHarmony開(kāi)發(fā)筆記(基于小型系統(tǒng))》第4章 OpenHarmony應(yīng)用開(kāi)發(fā)實(shí)例

這篇具有很好參考價(jià)值的文章主要介紹了《HarmonyOS開(kāi)發(fā) – OpenHarmony開(kāi)發(fā)筆記(基于小型系統(tǒng))》第4章 OpenHarmony應(yīng)用開(kāi)發(fā)實(shí)例。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請(qǐng)大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問(wèn)。

開(kāi)發(fā)環(huán)境
開(kāi)發(fā)系統(tǒng):Ubuntu 20.04
開(kāi)發(fā)板:Pegasus物聯(lián)網(wǎng)開(kāi)發(fā)板
MCU:Hi3861
OpenHarmony版本:3.0.1-LTS

4.1新建工程及配置

1.新建工程及源碼

  1. 新建目錄
$ mkdir hello

在applications/sample/myapp中新建src目錄以及myapp.c文件,代碼如下所示。

#include <stdio.h>
#include "ohos_init.h"
#include "ohos_types.h"

void app_task(void)
{
    printf("\n");
    printf("Hello hi3861!\n");
    printf("\n");
}
SYS_RUN(app_task);
  1. 新建編譯組織文件

新建applications/sample/myapp/BUILD.gn文件,內(nèi)容如下所示:

static_library("myapp") {
    sources = [
        "src/myapp.c"
    ]
    include_dirs = [
        "http://utils/native/lite/include"
    ]
}

static_library中指定業(yè)務(wù)模塊的編譯結(jié)果,為靜態(tài)庫(kù)文件libmyapp.a,開(kāi)發(fā)者根據(jù)實(shí)際情況完成填寫(xiě)。

sources中指定靜態(tài)庫(kù).a所依賴(lài)的.c文件及其路徑,若路徑中包含"http://“則表示絕對(duì)路徑(此處為代碼根路徑),若不包含”//"則表示相對(duì)路徑。

include_dirs中指定source所需要依賴(lài)的.h文件路徑

新建的工程目錄如下:

$ tree

《HarmonyOS開(kāi)發(fā) – OpenHarmony開(kāi)發(fā)筆記(基于小型系統(tǒng))》第4章 OpenHarmony應(yīng)用開(kāi)發(fā)實(shí)例

2.添加新組件
修改文件build/lite/components/applications.json,添加組件hello_world_app的配置。

{
      "component": "my_app",
      "description": "appsamples.",
      "optional": "true",
      "dirs": [
        "applications/sample/myapp"
      ],
      "targets": [
        "http://applications/sample/myapp:myapp"
      ],
      "rom": "",
      "ram": "",
      "output": [],
      "adapted_kernel": [ "liteos_m" ],
      "features": [],
      "deps": {
        "components": [],
        "third_party": []
      }
    },

《HarmonyOS開(kāi)發(fā) – OpenHarmony開(kāi)發(fā)筆記(基于小型系統(tǒng))》第4章 OpenHarmony應(yīng)用開(kāi)發(fā)實(shí)例

3.修改單板配置文件

修改文件vendor/hisilicon/hispark_pegasus/config.json,新增my_app組件的條目。

{
     "subsystem": "applications",
      "components": [
{ "component": "wifi_iot_sample_app ", "features":[] }
       { "component": "my_app", "features":[] }
      ]
},

《HarmonyOS開(kāi)發(fā) – OpenHarmony開(kāi)發(fā)筆記(基于小型系統(tǒng))》第4章 OpenHarmony應(yīng)用開(kāi)發(fā)實(shí)例

4.關(guān)閉xts測(cè)試子系統(tǒng)。
系統(tǒng)每次開(kāi)機(jī)后都要跑xts認(rèn)證程序,這里先刪除該部分內(nèi)容。

《HarmonyOS開(kāi)發(fā) – OpenHarmony開(kāi)發(fā)筆記(基于小型系統(tǒng))》第4章 OpenHarmony應(yīng)用開(kāi)發(fā)實(shí)例

4.2編譯下載驗(yàn)證

接下來(lái)就可以編譯了。

$ hb set

《HarmonyOS開(kāi)發(fā) – OpenHarmony開(kāi)發(fā)筆記(基于小型系統(tǒng))》第4章 OpenHarmony應(yīng)用開(kāi)發(fā)實(shí)例

全編譯。

$ hb build -f

《HarmonyOS開(kāi)發(fā) – OpenHarmony開(kāi)發(fā)筆記(基于小型系統(tǒng))》第4章 OpenHarmony應(yīng)用開(kāi)發(fā)實(shí)例

成功編譯后,固件在out/hispark_pegasus/wifiiot_hispark_pegasus目錄下。

《HarmonyOS開(kāi)發(fā) – OpenHarmony開(kāi)發(fā)筆記(基于小型系統(tǒng))》第4章 OpenHarmony應(yīng)用開(kāi)發(fā)實(shí)例

Hi3861_wifiiot_app_allinone.bin就是需要燒寫(xiě)的固件。

然后把固件下載到板子中。

《HarmonyOS開(kāi)發(fā) – OpenHarmony開(kāi)發(fā)筆記(基于小型系統(tǒng))》第4章 OpenHarmony應(yīng)用開(kāi)發(fā)實(shí)例

接下來(lái)就可以根據(jù)該實(shí)例開(kāi)發(fā)自己的應(yīng)用了。

4.3系統(tǒng)啟動(dòng)流程分析

下面簡(jiǎn)單分析下系統(tǒng)的啟動(dòng)流程,系統(tǒng)的入口函數(shù)是app_main(),在device/hisilicon/hispark_pegasus/sdk_liteos/app/wifiiot_app/src/app_main.c文件中。

hi_void app_main(hi_void)
{
#ifdef CONFIG_FACTORY_TEST_MODE
        printf("factory test mode!\r\n");
#endif

    const hi_char* sdk_ver = hi_get_sdk_version();
    printf("sdk ver:%s\r\n", sdk_ver);

    hi_flash_partition_table *ptable = HI_NULL;

    peripheral_init();
    peripheral_init_no_sleep();

#ifndef CONFIG_FACTORY_TEST_MODE
    hi_lpc_register_wakeup_entry(peripheral_init);
#endif

    hi_u32 ret = hi_factory_nv_init(HI_FNV_DEFAULT_ADDR, HI_NV_DEFAULT_TOTAL_SIZE, HI_NV_DEFAULT_BLOCK_SIZE);
    if (ret != HI_ERR_SUCCESS) {
        printf("factory nv init fail\r\n");
    }

    /* partion table should init after factory nv init. */
    ret = hi_flash_partition_init();
    if (ret != HI_ERR_SUCCESS) {
        printf("flash partition table init fail:0x%x \r\n", ret);
    }
    ptable = hi_get_partition_table();

    ret = hi_nv_init(ptable->table[HI_FLASH_PARTITON_NORMAL_NV].addr, ptable->table[HI_FLASH_PARTITON_NORMAL_NV].size,
        HI_NV_DEFAULT_BLOCK_SIZE);
    if (ret != HI_ERR_SUCCESS) {
        printf("nv init fail\r\n");
    }

#ifndef CONFIG_FACTORY_TEST_MODE
    hi_upg_init();
#endif

    /* if not use file system, there is no need init it */
    hi_fs_init();

    (hi_void)hi_event_init(APP_INIT_EVENT_NUM, HI_NULL);
    hi_sal_init();
    /* 此處設(shè)為T(mén)RUE后中斷中看門(mén)狗復(fù)位會(huì)顯示復(fù)位時(shí)PC值,但有復(fù)位不完全風(fēng)險(xiǎn),量產(chǎn)版本請(qǐng)務(wù)必設(shè)為FALSE */
    hi_syserr_watchdog_debug(HI_FALSE);
    /* 默認(rèn)記錄宕機(jī)信息到FLASH,根據(jù)應(yīng)用場(chǎng)景,可不記錄,避免頻繁異常宕機(jī)情況損耗FLASH壽命 */
    hi_syserr_record_crash_info(HI_TRUE);

    hi_lpc_init();
    hi_lpc_register_hw_handler(config_before_sleep, config_after_sleep);

#if defined(CONFIG_AT_COMMAND) || defined(CONFIG_FACTORY_TEST_MODE)
    ret = hi_at_init();
    if (ret == HI_ERR_SUCCESS) {
        hi_at_sys_cmd_register();
    }
#endif

    /* 如果不需要使用Histudio查看WIFI驅(qū)動(dòng)運(yùn)行日志等,無(wú)需初始化diag */
    /* if not use histudio for diagnostic, diag initialization is unnecessary */
    /* Shell and Diag use the same uart port, only one of them can be selected */
#ifndef CONFIG_FACTORY_TEST_MODE

#ifndef ENABLE_SHELL_DEBUG
#ifdef CONFIG_DIAG_SUPPORT
    (hi_void)hi_diag_init();
#endif
#else
    (hi_void)hi_shell_init();
#endif

    tcpip_init(NULL, NULL);
#endif

    ret = hi_wifi_init(APP_INIT_VAP_NUM, APP_INIT_USR_NUM);
    if (ret != HISI_OK) {
        printf("wifi init failed!\n");
    } else {
        printf("wifi init success!\n");
    }
    app_demo_task_release_mem(); /* 釋放系統(tǒng)棧內(nèi)存所使用任務(wù) */

#ifndef CONFIG_FACTORY_TEST_MODE
    app_demo_upg_init();
#ifdef CONFIG_HILINK
    ret = hilink_main();
    if (ret != HISI_OK) {
        printf("hilink init failed!\n");
    } else {
        printf("hilink init success!\n");
    }
#endif
#endif
    OHOS_Main();
}

該函數(shù)首先打印SDK的版本信息,然后掛載文件系統(tǒng),初始化WiFi信息等等一系列初始化,接這就到OHOS_Main(),該函數(shù)就是OpenHarmony系統(tǒng)的初始化。OHOS_Main()函數(shù)在文件device/hisilicon/hispark_pegasus/sdk_liteos/app/wifiiot_app/src/ohos_main.c中。

void OHOS_Main()
{
#if defined(CONFIG_AT_COMMAND) || defined(CONFIG_FACTORY_TEST_MODE)
    hi_u32 ret;
    ret = hi_at_init();
    if (ret == HI_ERR_SUCCESS) {
        hi_u32 ret2 = hi_at_register_cmd(G_OHOS_AT_FUNC_TBL, OHOS_AT_FUNC_NUM);
        if (ret2 != HI_ERR_SUCCESS) {
            printf("Register ohos failed!\n");
        }
    }
#endif
    OHOS_SystemInit();
}

值得注意的是OHOS_SystemInit()函數(shù)是一個(gè)弱函數(shù),其定義如下:

void __attribute__((weak)) OHOS_SystemInit(void)
{
    return;
}

因此該函數(shù)主要是系統(tǒng)為應(yīng)用開(kāi)發(fā)者提供的。OHOS_SystemInit()函數(shù)在base/startup/bootstrap_lite/services/source/system_init.c文件中。

void OHOS_SystemInit(void)
{
    MODULE_INIT(bsp);
    MODULE_INIT(device);
    MODULE_INIT(core);
    SYS_INIT(service);
    SYS_INIT(feature);
    MODULE_INIT(run);
    SAMGR_Bootstrap();
}

到這里基本就完成了所得初始化,其中我們編寫(xiě)的應(yīng)用就是MODULE_INIT(run)中完成的。
在base/startup/bootstrap_lite/services/source/core_main.h文件中,有如下定義:
MODULE_INIT定義如下:

#define MODULE_INIT(name)     \
    do {                      \
        MODULE_CALL(name, 0); \
    } while (0)

MODULE_CALL定義如下:

#define MODULE_CALL(name, step)                                      \
    do {                                                             \
        InitCall *initcall = (InitCall *)(MODULE_BEGIN(name, step)); \
        InitCall *initend = (InitCall *)(MODULE_END(name, step));    \
        for (; initcall < initend; initcall++) {                     \
            (*initcall)();                                           \
        }                                                            \
    } while (0)

模塊的名字定義如下:
#define MODULE_NAME(name, step) “.zinitcall.” #name #step “.init”
而SYS_RUN在utils/native/lite/include/ohos_init.h中定義。

/**
 * @brief Identifies the entry for initializing and starting a system running phase by the
 * priority 2.
 *
 * This macro is used to identify the entry called at the priority 2 in the system startup
 * phase of the startup process. \n
 *
 * @param func Indicates the entry function for initializing and starting a system running phase.
 * The type is void (*)(void).
 */
#define SYS_RUN(func) LAYER_INITCALL_DEF(func, run, "run")

而LAYER_INITCALL_DEF定義如下:

#define LAYER_INITCALL(func, layer, clayer, priority)                                     \
    static __attribute__((constructor(CTOR_VALUE_##layer + LAYER_INIT_LEVEL_##priority))) \
        void BOOT_##layer##priority##func() {func();}
#else
#define LAYER_INITCALL(func, layer, clayer, priority)            \
    static const InitCall USED_ATTR __zinitcall_##layer##_##func \
        __attribute__((section(".zinitcall." clayer #priority ".init"))) = func
#endif
// Default priority is 2, priority range is [0, 4]
#define LAYER_INITCALL_DEF(func, layer, clayer) \
    LAYER_INITCALL(func, layer, clayer, 2)

可以看到最終SYS_RUN宏定義都是定義在.zinitcall中,因此SYS_RUN()宏設(shè)置的函數(shù)都會(huì)在MODULE_INIT(run)完成調(diào)用。

好了,最后看看應(yīng)用啟動(dòng)的調(diào)用流程:

《HarmonyOS開(kāi)發(fā) – OpenHarmony開(kāi)發(fā)筆記(基于小型系統(tǒng))》第4章 OpenHarmony應(yīng)用開(kāi)發(fā)實(shí)例

官方文檔



歡迎訪(fǎng)問(wèn)我的網(wǎng)站

BruceOu的嗶哩嗶哩
BruceOu的主頁(yè)
BruceOu的博客
BruceOu的CSDN博客
BruceOu的簡(jiǎn)書(shū)
BruceOu的知乎


歡迎訂閱我的微信公眾號(hào)

關(guān)注公眾號(hào)[嵌入式實(shí)驗(yàn)樓]]獲取更多資訊文章來(lái)源地址http://www.zghlxwxcb.cn/news/detail-485693.html

到了這里,關(guān)于《HarmonyOS開(kāi)發(fā) – OpenHarmony開(kāi)發(fā)筆記(基于小型系統(tǒng))》第4章 OpenHarmony應(yīng)用開(kāi)發(fā)實(shí)例的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來(lái)自互聯(lián)網(wǎng)用戶(hù)投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場(chǎng)。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請(qǐng)注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請(qǐng)點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • HarmonyOS/OpenHarmony應(yīng)用開(kāi)發(fā)-ArkTS語(yǔ)言基本語(yǔ)法說(shuō)明

    HarmonyOS/OpenHarmony應(yīng)用開(kāi)發(fā)-ArkTS語(yǔ)言基本語(yǔ)法說(shuō)明

    圖1? 示例效果圖 ? 本示例中,ArkTS的基本組成如下所示。 圖2? ArkTS的基本組成 ? ? 裝飾器: 用于裝飾類(lèi)、結(jié)構(gòu)、方法以及變量,并賦予其特殊的含義。如上述示例中@Entry、@Component和@State都是裝飾器,@Component表示自定義組件,@Entry表示該自定義組件為入口組件,@State表示組

    2024年02月07日
    瀏覽(37)
  • HarmonyOS/OpenHarmony(Stage模型)應(yīng)用開(kāi)發(fā)單一手勢(shì)(二)

    HarmonyOS/OpenHarmony(Stage模型)應(yīng)用開(kāi)發(fā)單一手勢(shì)(二)

    三、拖動(dòng)手勢(shì)(PanGesture) .PanGestureOptions(value?:{ fingers?:number; direction?:PanDirection; distance?:number}) 拖動(dòng)手勢(shì)用于觸發(fā)拖動(dòng)手勢(shì)事件,滑動(dòng)達(dá)到最小滑動(dòng)距離(默認(rèn)值為5vp)時(shí)拖動(dòng)手勢(shì)識(shí)別成功,擁有三個(gè)可選參數(shù): fingers:非必選參數(shù),用于聲明觸發(fā)拖動(dòng)手勢(shì)所需要的最少手指數(shù)

    2024年02月09日
    瀏覽(31)
  • HarmonyOS/OpenHarmony(Stage模型)應(yīng)用開(kāi)發(fā)單一手勢(shì)(三)

    HarmonyOS/OpenHarmony(Stage模型)應(yīng)用開(kāi)發(fā)單一手勢(shì)(三)

    RotationGesture (value?:{ fingers ? :number ; angle ? :number }) 旋轉(zhuǎn)手勢(shì)用于觸發(fā)旋轉(zhuǎn)手勢(shì)事件,觸發(fā)旋轉(zhuǎn)手勢(shì)的最少手指數(shù)量為2指,最大為5指,最小改變度數(shù)為1度,擁有兩個(gè)可選參數(shù): fingers:非必選參數(shù),用于聲明觸發(fā)旋轉(zhuǎn)手勢(shì)所需要的最少手指數(shù)量,最小值為2,最大值為5,默認(rèn)值

    2024年02月09日
    瀏覽(25)
  • HarmonyOS/OpenHarmony應(yīng)用開(kāi)發(fā)-Stage模型應(yīng)用/組件級(jí)配置

    HarmonyOS/OpenHarmony應(yīng)用開(kāi)發(fā)-Stage模型應(yīng)用/組件級(jí)配置

    在開(kāi)發(fā)應(yīng)用時(shí),需要配置應(yīng)用的一些標(biāo)簽,例如應(yīng)用的包名、圖標(biāo)等標(biāo)識(shí)特征的屬性。本文描述了在開(kāi)發(fā)應(yīng)用需要配置的一些關(guān)鍵標(biāo)簽。圖標(biāo)和標(biāo)簽通常一起配置,可以分為應(yīng)用圖標(biāo)、應(yīng)用標(biāo)簽和入口圖標(biāo)、入口標(biāo)簽,分別對(duì)應(yīng) app.json5配置文件 和 module.json5配置文件 文件中的

    2024年02月13日
    瀏覽(21)
  • HarmonyOS/OpenHarmony應(yīng)用開(kāi)發(fā)-程序包多HAP機(jī)制(下)

    HarmonyOS/OpenHarmony應(yīng)用開(kāi)發(fā)-程序包多HAP機(jī)制(下)

    三、多HAP的開(kāi)發(fā)調(diào)試與發(fā)布部署流程 (一)多HAP的開(kāi)發(fā)調(diào)試與發(fā)布部署流程如下圖所示。 圖1?多HAP的開(kāi)發(fā)調(diào)試與發(fā)布部署流程 ? (二)開(kāi)發(fā) 開(kāi)發(fā)者通過(guò)DevEco Studio工具按照業(yè)務(wù)的需要?jiǎng)?chuàng)建多個(gè)Module,在相應(yīng)的Module中完成自身業(yè)務(wù)的開(kāi)發(fā)。 (三)調(diào)試 通過(guò)DevEco Studio編譯打包

    2024年02月17日
    瀏覽(23)
  • HarmonyOS/OpenHarmony應(yīng)用開(kāi)發(fā)-程序包多HAP機(jī)制(上)

    HarmonyOS/OpenHarmony應(yīng)用開(kāi)發(fā)-程序包多HAP機(jī)制(上)

    一、多HAP機(jī)制設(shè)計(jì)目標(biāo) 方便開(kāi)發(fā)者模塊化的管理應(yīng)用,好的應(yīng)用一般都是模塊化管理,模塊之間屬于松耦合關(guān)系。多HAP方便了開(kāi)發(fā)者將業(yè)務(wù)劃分成多個(gè)模塊,每個(gè)模塊放到獨(dú)立的HAP中。例如支付類(lèi)應(yīng)用,有統(tǒng)一的主界面,主界面管理“掃一掃”、“收付款”、“消息”、“理

    2024年02月15日
    瀏覽(28)
  • HarmonyOS/OpenHarmony應(yīng)用開(kāi)發(fā)-ArkTS語(yǔ)言聲明式UI描述

    ArkTS以聲明方式組合和擴(kuò)展組件來(lái)描述應(yīng)用程序的UI,同時(shí)還提供了基本的屬性、事件和子組件配置方法,幫助開(kāi)發(fā)者實(shí)現(xiàn)應(yīng)用交互邏輯。 一、創(chuàng)建組件 根據(jù)組件構(gòu)造方法的不同,創(chuàng)建組件包含有參數(shù)和無(wú)參數(shù)兩種方式。 說(shuō)明,創(chuàng)建組件時(shí)不需要new運(yùn)算符。 1.無(wú)參數(shù) 如果組

    2024年02月08日
    瀏覽(21)
  • HarmonyOS/OpenHarmony應(yīng)用開(kāi)發(fā)-Stage模型ArkTS語(yǔ)言FormExtensionAbility

    FormExtensionAbility模塊提供了卡片擴(kuò)展相關(guān)接口。 說(shuō)明 : 模塊首批接口從API version 9 開(kāi)始支持。模塊接口僅可在Stage模型下使用。 導(dǎo)入模塊 : import FormExtensionAbility from \\\'@ohos.app.form.FormExtensionAbility\\\'; 屬性: 名稱(chēng) 類(lèi)型 可讀 可寫(xiě) 說(shuō)明 context FormExtensionContext 是 否 FormExtensionAbility的上下

    2024年02月01日
    瀏覽(25)
  • HarmonyOS/OpenHarmony應(yīng)用開(kāi)發(fā)-Stage模型UIAbility組件使用(一)

    HarmonyOS/OpenHarmony應(yīng)用開(kāi)發(fā)-Stage模型UIAbility組件使用(一)

    一、UIAbility組件概述 1.概述 UIAbility組件是一種包含UI界面的應(yīng)用組件,主要用于和用戶(hù)交互。 UIAbility組件是系統(tǒng)調(diào)度的基本單元,為應(yīng)用提供繪制界面的窗口;一個(gè)UIAbility組件中可以通過(guò)多個(gè)頁(yè)面來(lái)實(shí)現(xiàn)一個(gè)功能模塊。每一個(gè)UIAbility組件實(shí)例,都對(duì)應(yīng)于一個(gè)最近任務(wù)列表中的

    2024年02月11日
    瀏覽(33)
  • HarmonyOS/OpenHarmony應(yīng)用開(kāi)發(fā)-Stage模型UIAbility組件使用(五)

    HarmonyOS/OpenHarmony應(yīng)用開(kāi)發(fā)-Stage模型UIAbility組件使用(五)

    UIAbility組件間交互(設(shè)備內(nèi)) UIAbility是系統(tǒng)調(diào)度的最小單元。在設(shè)備內(nèi)的功能模塊之間跳轉(zhuǎn)時(shí),會(huì)涉及到啟動(dòng)特定的UIAbility,該UIAbility可以是應(yīng)用內(nèi)的其他UIAbility,也可以是其他應(yīng)用的UIAbility(例如啟動(dòng)三方支付UIAbility)。 本文將從如下場(chǎng)景分別介紹設(shè)備內(nèi)UIAbility間的交互

    2024年02月16日
    瀏覽(29)

覺(jué)得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請(qǐng)作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包