花粉乐分享平台宣传视频
> 华为资讯 > 华为资讯 > 鸿蒙编程 > 尝鲜!我在华为鸿蒙上编写的第一个 Hello World
尝鲜!我在华为鸿蒙上编写的第一个 Hello World
来源:老炮说Java
2022-12-02 14:28:11
575
管理

最激动入门级选手的心的时刻来了,本示例将演示如何编写简单业务,输出“Hello World”。

修改源码

bugfix和新增业务两种情况,涉及源码修改。下面以新增业务举例,向开发者介绍如何进行源码修改。

1.确定目录结构。

开发者编写业务时,务必先在./applications/sample/wifi-iot/app路径下新建一个目录(或一套目录结构),用于存放业务源码文件。

例如:在app下新增业务my_first_app,其中hello_world.c为业务代码,BUILD.gn为编译脚本,具体规划目录结构如下:

.└── applications    └── sample        └── wifi-iot            └── app                │── my_first_app                │  │── hello_world.c                │  └── BUILD.gn                └── BUILD.gn

2.编写业务代码。

在hello_world.c中新建业务入口函数HelloWorld,并实现业务逻辑。并在代码最下方,使用OpenHarmony启动恢复模块接口SYS_RUN()启动业务。(SYS_RUN定义在ohos_init.h文件中)

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

3.编写用于将业务构建成静态库的BUILD.gn文件。

如步骤1所述,BUILD.gn文件由三部分内容(目标、源文件、头文件路径)构成,需由开发者完成填写。以my_first_app为例,需要创建./applications/sample/wifi-iot/app/my_first_app/BUILD.gn,并完如下配置。

static_library("myapp") {    sources = [        "hello_world.c"    ]    include_dirs = [        "//utils/native/liteos/include"    ]}static_library中指定业务模块的编译结果,为静态库文件libmyapp.a,开发者根据实际情况完成填写。sources中指定静态库.a所依赖的.c文件及其路径,若路径中包含"//"则表示绝对路径(此处为代码根路径),若不包含"//"则表示相对路径。include_dirs中指定source所需要依赖的.h文件路径。

4.编写模块BUILD.gn文件,指定需参与构建的特性模块。

配置./applications/sample/wifi-iot/app/BUILD.gn文件,在features字段中增加索引,使目标模块参与编译。features字段指定业务模块的路径和目标,以my_first_app举例,features字段配置如下。

import("//build/lite/config/component/lite_component.gni")lite_component("app") {    features = [        "my_first_app:myapp",    ]}my_first_app是相对路径,指向./applications/sample/wifi-iot/app/my_first_app/BUILD.gn。myapp是目标,指向./applications/sample/wifi-iot/app/my_first_app/BUILD.gn中的static_library("myapp")。调测验证

目前调试验证的方法有两种,分别为通过printf打印日志、通过asm文件定位panic问题,开发者可以根据具体业务情况选择。

由于本示例业务简单,采用printf打印日志的调试方式即可。下面开始介绍这两种调试手段的使用方法。

printf打印

代码中增加printf维测,信息会直接打印到串口上。开发者可在业务关键路径或业务异常位置增加日志打印,如下所示。

void HelloWorld(void){    printf("[DEMO] Hello world.n");}根据asm文件进行问题定位

系统异常退出时,会在串口上打印异常退出原因调用栈信息,如下文所示。通过解析异常栈信息可以定位异常位置。

=======KERNEL PANIC=======**********************Call Stack*********************Call Stack 0 -- 4860d8 addr:f784cCall Stack 1 -- 47b2b2 addr:f788cCall Stack 2 -- 3e562c addr:f789cCall Stack 3 -- 4101de addr:f78acCall Stack 4 -- 3e5f32 addr:f78ccCall Stack 5 -- 3f78c0 addr:f78ecCall Stack 6 -- 3f5e24 addr:f78fc********************Call Stack end*******************

为解析上述调用栈信息,需要使用到Hi3861_wifiiot_app.asm文件,该文件记录了代码中函数在Flash上的符号地址以及反汇编信息。asm文件会随版本大包一同构建输出,存放在./out/wifiiot/路径下。

1.将调用栈CallStack信息保存到txt文档中,以便于编辑。(可选)

2.打开asm文件,并搜索CallStack中的地址,列出对应的函数名 信息。通常只需找出前几个栈信息对应的函数,就可明确异常代码方向。

Call Stack 0 -- 4860d8 addr:f784c -- WadRecvCBCall Stack 1 -- 47b2b2 addr:f788c -- wal_sdp_process_rx_dataCall Stack 2 -- 3e562c addr:f789cCall Stack 3 -- 4101de addr:f78acCall Stack 4 -- 3e5f32 addr:f78ccCall Stack 5 -- 3f78c0 addr:f78ecCall Stack 6 -- 3f5e24 addr:f78fc

3.根据以上调用栈信息,可以定位WadRecvCB函数中出现了异常。

4.完成代码排查及修改。

运行结果

示例代码编译、烧录、运行、调测后,会显示如下结果

ready to OS startFileSystem mount ok.wifi init success![DEMO] Hello world.

来源:https://my.oschina.net/u/4518335/blog/4557426

作者 :阿拉蕾aaa

花粉社群VIP加油站

3
点赞
赏礼
赏钱
0
收藏
免责声明:本文仅代表作者个人观点,与花粉乐分享无关。其原创性以及文中陈述文字和内容未经本网证实,对本文以及其中全部或者 部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
凡本网注明 “来源:XXX(非花粉乐分享)”的作品,均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对 其真实性负责。
如因作品内容、版权和其它问题需要同本网联系的,请在一周内进行,以便我们及时处理。
QQ:2443165046 邮箱:info@hflfx.com
关于作者
华为派(采蜜高手)
文章
471
主题
0
关注
0
粉丝
1
点击领取今天的签到奖励!
签到排行
随手拍
54个圈友 0个话题
华为手机随手拍,记录生活点滴之美好
华为P30pro
51个圈友 0个话题
这里是华为P30pro手机交流圈,欢迎华为P30pro用户进群交流
体验官
60个圈友 2个话题
华为花粉体验官,体验官专属的交流群
登录后查看您创建的圈子
登录后查看您创建的圈子
所有圈子
杭州互联网违法和不良信息举报平台 网络110报警服务 浙ICP备17046585号
3
0
分享
请选择要切换的马甲:

个人中心

每日签到

我的消息

内容搜索