学习鸿蒙先解决这几个是关键问题~

HarmonyOS 是最近最火的操作系统,HarmonyOS 宣布删除 Android 代码之后,正式向世界上第三大操作系统有迈进了一步,HarmonyOS 前期为了完成从 Android 到 HarmonyOS 的过渡,在设计之初 HarmonyOS 采用了双框架架构设计。

从图中可以看出无论 HarmonyOS 还是 Android 底层都是 Linux 内核,在 Linux 内核的上一层,还有硬件抽象层,从这一层开始将 HarmonyOS 和 Android 分为了两部分,等到发展到一定阶段之后,HarmonyOS 部分会逐步替换掉 Android 部分。

如今 HarmonyOS 完全去 Android 化势在必行了,在技术多变的时代,顺应技术的趋势,我们也不得不去学习 HarmonyOS,我也开始准备更新鸿蒙系列文章了,这次鸿蒙系列文章会以文章 + 案例 + 实战项目的形式分享给正在学习鸿蒙的小伙伴。

在学习 HarmonyOS 过程中,发现 HarmonyOS 的问题太多了,而且很多问题在网上都找不到答案,只能自己一点一点去摸索,走了不少弯路,这篇文章主要记录了我在学习鸿蒙过程中遇到的问题,分享给正在学习的鸿蒙的你,避免少走一些弯路。

鸿蒙目前还处于初期发展阶段,网上对鸿蒙问题的解答太少了,而群是一个非常好的沟通渠道,相比于自己去摸索,通过与大家的沟通交流,效率会提高很多。所以我想建一个鸿蒙学习交流群,诚邀各位小伙伴一起来打造一个良好的学习氛围沟通群。

但是我不知道有多少人对鸿蒙开发感兴趣,因此我想做个简单的统计,正在学习或者对鸿蒙感兴趣的,可以在文章中右下角点个在看,或者给这篇文章点个赞。如果学习的人多的话,我们可以拉个群,互相分享经验。

Stage 模型与 FA 模型的区别

当我们创建 Harmony 工程的时候,会让我们选择工程的模型。

Harmony 的工程模型,分别为 Stage 模型与 FA 模型。

  • FA 模型:Harmony 初期的模型,仅适用简单的应用开发,比如笔记本、闹钟之类的软件。因为在 FA 模型,每个应用组件独享一个虚拟机,占用的运行内存会更多

  • Stage 模型:官方推荐的模型,相比于 FA 模型它适用于复杂应用开发。在 Stage 模型中多个应用组件共享同一个虚拟机,可以减少运行内存的占用,同时为了降低性能的损耗,保障用户体验,Harmony 对后台应用会有严格的管理机制

Harmony 后台管理机制

Harmony 对后台应用会有严格的管理机制,普通应用是不能随意驻留在后台,除非你的应用是国民级别的应用,Harmony 对后台应用会进行有序的治理,系统定义了四类后台任务。在这里只需要了解即可,后面的文章我会详细的分析。

配置环境变量

无论是开发 Android 还是开发 HarmonyOS,第一步都是要配置好环境变量,方便后期使用。

在命令行中配置 hdc

hdc 等同于 adb 是 HarmonyOS 为开发人员提供的用于调试的命令行工具,通过该工具可以在 windows/linux/mac 系统上与真实设备或者模拟器进行交互。

Mac 在不同的系统中使用不同的 shell, 使用下面命令查看自己使用的是哪一个 shell。

echo $SHELL 
  • 如果输出结果为 /bin/bash,你的配置文件是 .bash_profile,打开文件命令 vi .bash_profile

  • 如果输出结果为 /bin/zsh,你的配置文件是 .zshrc, 打开文件命令 vi .zshrc

打开配置文件,将下面的内容添加到文件末尾。记得将「用户名目录」修改为你电脑的用户名。

export HARMONY\_HOME\=/Users/用户名目录/Library/Huawei  
export HARMONY\_SDK\_HOME\=$HARMONY\_HOME/sdk  
export PATH\=$HARMONY\_SDK\_HOME/hmscore/3.1.0/toolchains:$PATH

保存文件,执行下面命令立即生效。

  • 如果配置文件是 .bash_profile,执行 source ~/.bash_profile

  • 如果配置文件是 .zshrc,执行 source ~/.zshrc

最后验证 hdc 是否配置成功。

hdc \-v

hdc 和 adb 一样也有一堆命令,后期我会总结好分享给大家。

在命令行中配置 ohpm

OHPM CLI 作为鸿蒙生态三方库的包管理工具,支持 OpenHarmony 共享包的发布、安装和依赖管理。这个工具在开发中经常会用到,比如在模块中依赖三方库,我们可以使用 ohpm 下载安装第三方库。所以配置好 ohpm 环境变量,方便我们在开发中使用。

打开配置文件

  • 如果配置文件是 .bash_profile,执行 vi ~/.bash_profile

  • 如果配置文件是 .zshrc,执行 vi ~/.zshrc

将下面的内容,添加到配置文件末尾。记得将「用户名目录」修改为你电脑的用户名。

export HARMONY\_HOME\=/Users/用户名目录/Library/Huawei/  
export PATH\=$HARMONY\_HOME/ohpm/bin:$PATH

保存文件,执行下面命令立即生效。

  • 如果配置文件是 .bash_profile,执行 source ~/.bash_profile

  • 如果配置文件是 .zshrc,执行 source ~/.zshrc

最后验证 ohpm 是否配置成功。

ohpm \-v

但是在下载安装 ohpm 工具包和使用 ohpm 时可能会出现不同的错误,这里列了几个常见的错误。

ohpm install failed

Error: execute install task failed, component ohpm.zip.  
Error: execute 'ohpm install' failed.

这是由于 NPM 以前版本中的一个 bug 导致,运行下面的命令即可解决。

sudo chown -R 501:20 "/Users/替换为你mac的用户名/.npm"

ohpm registry is empty

创建 Harmony 项目之后 build 时可能出现 ohpm registry is empty 的错误。

ohpm ERROR: The registry is empty \- edit .ohpmrc file or use "ohpm config set registry your\_registry" command to set registry.  
ohpm ERROR: Install failed  

想解决这个问题,我们需要在 DevEco Studio 中配置 ohpm 仓库的地址,按照下面的路径打开 Ohpm 窗口。

DevEco Studio -> Perferences -> Build, Execution, Deployment -> Ohpm

点击 Optimize Config 会弹出了一个界面。

ohpm registry 中输入 ohpm 仓库的地址并勾选。

https://repo.harmonyos.com/ohpm/

保存成功之后,重新 build 项目即可成功。

真机和模拟器无法运行

首先检查你的 DevEco Studio 版本是否是 3.1 Release,这个版本可能存在一些问题。

真机无法连接

我用 usb 连接真机,在 DevEco Studio 设备管理器中无法显示,用命令查看已经连接上了,我猜测是这个版本的问题,于是我尝试降级到 DevEco Studio 3.1 Beta2 正常了。

本地模拟器无法运行

从 DevEco Studio 3.1 开始支持两个模拟器,API 版本分别为 6、9,无论哪个模拟器都无法运行。

于是我查看了 鸿蒙的开发文档 DevEco Studio >=3.1 本地模拟器仅支持以下系统中运行。

  • Windows 系统:内存推荐为 16GB 及以上。

  • macOS 系统:内存推荐为 8GB 及以上。如果是 ARM 版本的 macOS,macOS 版本需在 12.2 及以上,否则将无法运行本地模拟器。

但是我的 macOS 的版本是 12.5.1 不仅本地模拟器无法运行,而且真机连接了也无法显示。

我猜测这个问题应该也是 DevEco Studio 版本的原因,于是我尝试降级到 DevEco Studio 3.1 Beta2,成功运行 DevEco Studio 支持的模拟器。

但是这里需要注意的是如果你的 macOS >=10.14 and macOS < 12.2 只能运行 API 版本是 6 的模拟器。

如果有遇到和我一样问题的小伙伴,可以采用临时方案,尝试降级 DevEco Studio 版,等待官方解决吧。

如何解决安装错误

好不容易解决了开发工具的问题,满心欢喜想运行鸿蒙应用体验一下,结果安装应用时报错了,让我喝杯茶压压惊。

这是因为运行的设备(模拟器和真机)和 SDK 版本的不匹配,因此会报 INSTALL_PARSE_FAILED_USESDK_ERROR 错误。

想解决这个问题,需要将 compileSdkVersioncompatibleSdkVersion 以及 SDK 版本需要与运行设备的 apiVersion 对应起来。

但是我们不能简单修改配置文件中 compileSdkVersion 和 c ompatibleSdkVersion 的版本号,因为使用不同的 HarmonyOS Sdk 版本,创建的 HarmonyOS 工程的目录结构和开发语言都不相同。

  • API Version 4~7 构建体系是由 Gradle 构建工具和构建插件组成,不要基于这个版本去开发,不然后期从 Gradle 迁移到 Hvigor 是件非常痛苦的事

  • API Version 8~9 构建体系是由 Hvigor 构建工具和构建插件组成

开发语言也不一样:

  • API Version >= 9 仅仅支持 ArkTS

  • API Version == 8 支持 ArkTS 和 JS

  • API Version == 7 支持 ArkTS 、 JS 和 Java

  • API Version < 7 支持 JS 和 Java

所以我们不能简单的修改 compileSdkVersioncompatibleSdkVersion 的版本,对于我们初学者,如果出现这个问题,建议重新创建一个新的工程。

新建项目时 Compile Sdk 应该选择与你运行的设备(模拟器和真机) apiVersion 相对应的版本号。

如何查看运行的设备(模拟器和真机) apiVersion 的版本

这里我们需要用到 hdc 工具,hdc 的配置在前面已经介绍过了,hdc 的用法等价于 adbhdc 如何使用,后期我会总结好分享给大家。

hdc shell  
getprop hw\_sc.build.os.apiversion

输出结果即是设备(模拟器和真机) apiVersion 的版本。

运行项目常见错误

当我以为一切都正常的时候,运行项目,有出现了一个新的错误,真令人崩溃,跑起一个项目怎么这么难。

对应的错误信息。

{  
 instancePath: 'app.compileSdkVersion',  
 keyword: 'exclusiveMinimum',  
 params: { comparison: '>', limit: 7 },  
 message: 'must be > 7',  
 location: '/Users/用户名目录/Documents/codebase/harmonyOs/Application/build-profile.json5:4:27'  
}

这是因为创建的是 Hvigor 工程,而 Hvigor 工程支持最低的 apiVersion 版本是 7,而我修改了 apiVersion 的版本 < 7, 因此运行的时候会出现上面的错误。因此我们应该选择 Compile Sdk 和你运行设备(模拟器和真机) apiVersion 相对应的版本号。

在鸿蒙模拟器,运行 Android 应用

Android 同学都体验过 Android Studio 自带的模拟器是多么的难用,网上也有很多 Android 模拟器,但是安装的门槛高,而且安装好了运行会出现很多问题,体验也不是那么的好。

DevEco Studio 提供的模拟器,相比于其它的模拟器,非常的好用,Android 同学可以在下载体验一下,在鸿蒙的模拟器上安装 Android 应用,对于简单的应用体验还是可以的。而且 DevEco Studio 的模拟器安装非常的简单。

如何安装鸿蒙的模拟器

按照图示方式打开 Device Manager。

点击 New Emulator 按钮,按照图示,操作即可。

如何安装 Android 应用到鸿蒙的模拟器

但是我们需要修改 Android 项目支持的 CPU/API 版本。因为 Harmony 的模拟器 CPU/API 是 x86,所以需要在 build.gradle 文件中添加 x86 的支持。

android {  
 compileSdkVersion 33  
 defaultConfig {  
 ndk {  
 abiFilters 'x86\_64','x86'  
 }  
 }  
}

DevEco Studio 和 Android Studio 样式文件共享

DevEco Studio 和 Android Studio 都是基于 idea 开发的,所以如果习惯了 Android Studio 开发界面,我们可以把 Android Studio 界面的样式,导入到 DevEco Studio 中。

如何导出 Android Studio 界面的样式

如何导入 Android Studio 界面的样式到 DevEco Studio

最终的效果对比。DevEco Studio 和 Android Studio 都支持定义自己的外观样式,大家可以按需定制。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,670评论 5 460
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,928评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,926评论 0 320
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,238评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,112评论 4 356
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,138评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,545评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,232评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,496评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,596评论 2 310
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,369评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,226评论 3 313
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,600评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,906评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,185评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,516评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,721评论 2 335

推荐阅读更多精彩内容