当前位置: 首页 > ai >正文

2.在Openharmony写hello world

原文链接:https://kashima19960.github.io/2025/03/21/openharmony/2.在Openharmony写hello%20world/

前言

Openharmony 的第一个官方例程的是教你在Hi3861上编写hello world程序,这个例程相当简单编写 Hello World”程序,而且步骤也很省略,最重要的是这个例程 ,没有main函数都能运行!!官方所谓的“快速入门”其实是面向有基础的工程师,所以对于很多学识浅薄的学生来说,一看上去肯定会一脸懵逼。在这篇文章中,我会先过一遍例程,Openharmony的启动过程,你就明白main函数哪去了

hello world

Openharmony规定了用户编写自己代码的位置,所以要把代码放在指定目录里面

确定目录结构

applications/sample/wifi-iot/app 新建一个目录,这个目录的名字可以随便取,这里就取为my_first_app,在这个目录创建代码文件,和一个BUILD.gn编译脚本,如果不知道这个编译脚本是什么可以先不用管

在这里插入图片描述

如果还是不太懂就看一下总览的结构

image-20250327102835663

编写配置文件和代码

然后就可以开始编写相应文件的内容了,这里BUILD.gn有两个,一个是在``applications/sample/wifi-iot/app文件夹下,这个是外层的构建脚本,还有一个就是在自己建立的my_first_app`文件夹下,这个是内层的构建脚本。因为GN有自己的语法,所以你不懂的话,就先复制粘贴模仿一下

外层BUILD.gn内容

import("//build/lite/config/component/lite_component.gni")lite_component("app") {features = ["startup",#这个my_first_app就是文件夹的名字,这个hello_world要对应内层BUILD.gn中static_library括号里的内容"my_first_app:hello_world"]
}

内层BUILD.gn内容

static_library("hello_world") {sources = ["hello_world.c"]include_dirs = ["//utils/native/lite/include","//kernel/liteos_m/kal/cmsis","//base/iot_hardware/peripheral/interfaces/kits",]
}

以上的工作做好后,就可以开始写代码了,可以看到这里不需要main函数

#include <stdio.h>
#include "ohos_init.h"
#include "ohos_types.h"void HelloWorld(void)
{printf("[DEMO] Hello world.\n");
}
SYS_RUN(HelloWorld);

编译与烧录

编译方法有两种,一个是用hb工具,另一个用deveco device tool,但其实deveco device tool 也是用hb工具的,只是把编译操作做成一个按钮而已

image-20250327104345947

有提示success就算成功了

在这里插入图片描述

烧录方式也有两种,一个是用Hiburn,另一种是用deveco 的upload,上图有,那个upload就是烧录,之所以叫upload(上传),是因为要先把编译出来的镜像上传到Windows,然后再调用Hiburn烧录,所以这个``upload`底层是用的Hiburn,也是跟编译一样把某个底层工具封装成一个按钮

具体方法请参照官方文档

  • DevEco Device Tool烧录
  • Hiburn烧录

结果

image-20250327115628445

OpenHarmony启动的8个阶段

在系统启动过程中,服务和功能按以下顺序初始化

  • 阶段1. core
  • 阶段2. core system service
  • 阶段3. core system feature
  • 阶段4. system startup
  • 阶段5. system service
  • 阶段6. system feature
  • 阶段7. application-layer service
  • 阶段8. application-layer feature

ohos_init.h定义了8个宏,用于让一个函数以“优先级2”在系统启动过程的以上8个阶段执行。即函数会被标记为入口,在系统启动过程的1-8阶段,以“优先级2”被调用。

在这里插入图片描述

•在系统启动的某个阶段,会有多个函数被调用,优先级决定了调用顺序。

•优先级范围:0-4

•优先级顺序:0, 1, 2, 3, 4

前面代码中用到了SYS_RUN这个宏,就是让你自己写的函数以**“优先级2”在系统启动过程的“阶段4. system startup”阶段执行**。所以现在明白为啥没有main函数,你的代码都能被运行了吧,main函数是已经固化在系统里面了,你只能根据系统提供的特定的接口来把自己编写的功能放到系统里面。如果想要自己的函数在其他阶段运行,可以参照以下表格

宏定义启动阶段
CORE_INIT()阶段1. core
SYS_SERVICE_INIT()阶段2. core system service
SYS_FEATURE_INIT()阶段3. core system feature
SYS_RUN()阶段4. system startup
SYSEX_SERVICE_INIT()阶段5. system service
SYSEX_FEATURE_INIT()阶段6. system feature
APP_SERVICE_INIT()阶段7. application-layer service
APP_FEATURE_INIT()阶段8. application-layer feature
http://www.xdnf.cn/news/3874.html

相关文章:

  • 蓝桥杯 18. 积木
  • 记9(Torch
  • Leetcode刷题记录32——搜索二维矩阵 II
  • Dubbo(97)如何在物联网系统中应用Dubbo?
  • C语言 ——— 函数
  • Java设计模式: 工厂模式与策略模式
  • COlT_CMDB_linux_tomcat_20250505.sh
  • 【AI大模型】SpringBoot整合Spring AI 核心组件使用详解
  • 基于大模型的子宫腺肌病全流程预测与诊疗方案研究报告
  • 定位理论第一法则在医疗AI编程中的应用
  • Linux /dev/null文件用法介绍
  • 【KWDB 创作者计划】KWDB 2.2.0多模融合架构与分布式时序引擎
  • 如何选择合适的光源?
  • 【Linux网络#17】TCP全连接队列与tcpdump抓包
  • Linux55yum源配置、本机yum源备份,本机yum源配置,网络Yum源配置,自建yum源仓库
  • 人工智能数学基础(十)—— 图论
  • 告别散乱的 @ExceptionHandler:实现统一、可维护的 Spring Boot 错误处理
  • graphviz和dot绘制流程图
  • 金仓数据库 KingbaseES 在电商平台数据库迁移与运维中深入复现剖析
  • MongoDB 整合SpringBoot
  • Webug4.0靶场通关笔记12- 第17关 文件上传之前端拦截(3种方法)
  • Google Agent space时代,浅谈Agent2Agent (A2A) 协议和挑战!
  • 什么是右值引用和移动语义?大白话解释
  • 5个重要的财务指标讲解
  • Javase 基础加强 —— 02 泛型
  • SpringBoot中接口签名防止接口重放
  • Debezium Binlog解析与事件转换流程详解
  • Linux 入门:操作系统进程详解(上)
  • P3469 [POI 2008] BLO-Blockade
  • 字符串问题c++