0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

HarmonyOS与OpenHarmony开发角度上的区别

OpenHarmony技术社区 来源:鸿蒙技术社区 作者:软通夏德旺 2021-09-28 09:31 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

开篇第一句,所有学习与开发资料以官方资料为准。任何博客类只能作为参考,自行判断优良,不要被误导,包括本人的所有博客。

HarmonyOS 官方文档地址

应用开发:

https://developer.harmonyos.com/cn/documentation

设备开发:

https://device.harmonyos.com/

OpenHarmony 官方文档地址

如下:

https://gitee.com/openharmony/docs/

HarmonyOS 与 OpenHarmony 的区别

关于 HarmonyOS 与 OpenHarmony 的区别我这里不再过多阐述,请看开放原子基金会的官方介绍。

我这里着重从开发角度上讲解它们的区别:

①开发语言支持

HarmonyOS 主要支持 Java 和 JS 来开发应用(当然还有 C 和 C++),而 OpenHarmony 不支持 Java 来开发应用。

目前阶段 HarmonyOS 里面还是有部分功能是基于 AOSP 的,因此还是要用 Java,而 OpenHarmony 不再使用 Java,应该是想彻底放弃 AOSP 了。

SDK 的不同

应用开发工具都是统一使用华为的 DevEco Studio,但是使用的 sdk 不同,开发前首先要切换 sdk 配置。

虽然 HarmonyOS 和 OpenHarmony 都可以用 js 来开发应用,但是它们的 api 还是有些细微的区别。

OpenHarmony 的 api 参考请参看 OpenHarmony 的官方文档,千万别看错了。

然后 OpenHarmony 的 sdk 请下载官方的支持 OpenHarmony 开发的 sdk,而不是 DevEco studio 自带的 HarmonyOS sdk。

关于 OpenHarmony sdk 配置请参考官方文档,我这里仅仅附上官方链接:

https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/quick-start/配置OpenHarmony-SDK.md

③创建项目方式不同

在 DevEco 2.2 Beat1 版本之后,可以直接支持创建 OpenHarmony 应用项目了。

创建方式如下图:

这里重点对 standard 解释下,即 OpenHarmony 官方说的“标准系统”,本文中所说的所有 OpenHarmony 应用开发都是针对的标准系统。

轻量和小型系统(参考内存《128MB),标准系统(参考内存≥128MB),详细说明请看官方文档:

https://gitee.com/openharmony/docs/blob/master/zh-cn/readme.md

⑤运行调测方式不同

HarmonyOS 支持 previewer 预览、模拟器运行、真机运行三种方式;OpenHarmony 支持 previewer 预览、真机(目前主要使用 3516 系列开发板)运行。

首先,目前 OpenHarmony 是没有模拟器的,真正运行调测只能借助开发板(主要采用 HI3516 系列开发板),注意目前是不支持手机平板等真机调测的。

⑥签名方式不同

OpenHarmony 的签名方式我这里就不赘述,直接附上官方文档链接:

https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/quick-start/配置OpenHarmony应用签名信息.md

HarmonyOS 的签名我最想吐槽的就是需要添加设备 ID。OpenHarmony 的签名我只想吐槽一句,既然 open 为何还必须要签名。

埋坑

上面的区别对比已经埋了部分坑了,下面再针对纯粹上层应用开发人员初次接触 OpenHarmony 开发的坑。

①OpenHarmony 操作系统编译

为何要编译操作系统,如果你手上有现成的安装好操作系统的开发板你,操作系统和 sdk 版本也对应。

比如我们是基于 OpenHarmony-SDK-2.0-Canary 版本,那你应该烧录一个对应的操作系统版本。比如我手上是很久之前的一个 1.0 版本的 3516 开发板,显然要升级。

操作系统编译的完整资料依然请参考官网:

https://gitee.com/openharmony/docs/blob/master/zh-cn/device-dev/quick-start/quickstart-standard.md

关于这里我强调几点:

(1)使用 repo 进行代码仓同步时,官方描述的操作命令如下:

repo sync -c

建议替换成:

repo sync -c -j8

这个后面的数字 8 根据自己的 cpu 核数进行设置,查看 cpu 核数的命令如下:

grep -c ‘processor’ /proc/cpuinfo

35833592-1fc2-11ec-82a8-dac502259ad0.png

这样配置之后,会大大加快你的同步速度,否则这个同步时间会非常漫长。

同步过程请使用无限制的公网网络,比如某些公司访问外网会有限制。然后就是网络下载速度也会会直接关系到你的同步速度。

repo 中途同步失败了(比如断网或者异常关机),也不要过于紧张,可以根据 log 提示删除某些同步异常的部分仓库,然后继续执行上面的同步命令即可。

(2)编译环境安装时,Linux 编译服务器终端输入不识别的命令时,提示“ImportError: No module named apt_pkg”。

解决办法:执行如下命令重新安装 python3-apt。

sudo apt-get remove python3-apt

sudo apt-get install python3-apt

(3)编译构建时,我这里遇到一个大坑,就是电脑突然断电了,然后再执行编译的时候报大量错误,错误内容如下:

rm: cannot remove ‘XXXXX‘: Bad message

这种问题本来可以采用 fsck 的方式来修复文件系统,但是由于编译过程中产生了大量的很小的临时文件,所以修复起来太慢太不现实,干脆删除了虚拟机重新加载之前保存的虚拟机镜像,重新再来一次。

②操作系统烧录

官方描述的是使用网口进行烧录,官网地址如下:

https://gitee.com/openharmony/docs/blob/master/zh-cn/device-dev/quick-start/quickstart-standard-burn.md

需要注意的点:本文档针对的开发版是官方推荐的 AI_Camera_Hi3516DV300 开发套件。

(1)确保 USB 转串口驱动能安装上,即在 PC 的设备管理器上能识别到 COM 口。

首先安装 USB-to-Serial Comm Port.exe 驱动,如果没有识别请再安装 CH341SER 驱动。

(2)网口烧录注意事项:不支持无线,需要使用网线直连 PC,网卡是千兆网卡,最好选择六类网线,这样速度更快。

PC 端需要设置 ip 地址为 192.168.1.2/24,网关为 192.168.1.1,如下图:

烧录工具上网口的设置:

upload_net_server_ip:对应 PC 上网口设置的地址。

upload_net_client_mask:设置开发板的子网掩码,对应 PC 上设置的子网掩码,确保开发板和 PC 在一个网段。

upload_net_client_gw:和 PC 上设置的网关保持一致。

upload_net_client_ip:设置开发板的 IP 地址,例如 192.168.1.3,确保和 PC 在一个网段即可。

我没有使用官方推荐的 DevEco Device Tool 进行烧录,而是使用了我喜欢的 HiBurn 进行烧录,但是基本配置相同,截图如下:

点完烧写按钮之后,需要先下电再上电,上电之后就会自动进行烧写了。网口烧录时间比较慢,标准系统 2.2beta 版本烧录估计要 20 分钟。

(3)USB 烧录(强烈推荐,最快的方式,一分钟即可烧写完毕),这种方式是我在配置过程中最卡我的一种方式。主要就是 USB 的驱动一直无法识别。

首先我们来看看正确识别驱动之后,设备管理器中的页面,必须看到通用串行设备下识别了设备才行,如下图:

(1)开发套件上面有两个 typec 接口,屁股后面的那个才是 USB 口,前面的仅仅是供电口。

(2)安装 HiUSBBurnDriver 驱动程序。

(3)Win10 操作系统需要修改注册表。

a.创建一个“文本文档.TXT”,文件后缀名修改为 .reg,如 usb.reg。

b.右键打开创建的 usb.reg,将如下脚本拷贝到该文件中,然后保存并关闭。

Windows Registry Editor Version 5.00 [HKEY_LOCAL_MACHINESYSTEMCurrentControlSetControlusbflags12D1D0010100]“SkipBOSDescriptorQuery”=hex:01,00,00,00“osvc”=hex:00,00“IgnoreHWSerNum”=hex:01

c.双击执行 usb.reg 文件,自动修改注册表文件信息。

(4)我 PC 依然迟迟无法识别 USB 驱动的时候,我在系统的 boot 里面(串口终端连接下,进入 uboot 之前,狂按回车进入 boot)输入以下命令终于解决了无法识别驱动的问题。

usb device

(5)待识别了 USB 驱动之后烧录需要注意的问题。

设置好烧录镜像之后,在下电在上电之前,请一直按住开发板上面的 update 按钮(在开发板的串口旁边),上电之后,待出现开始烧写的打印之后再松开按钮。

③OpenHarmony 安装应用到开发板

此处依然贴出对应的官方文档:

https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/quick-start/安装运行OpenHarmony应用.md

这里使用的是 hdc_std.exe,而不是 HarmonyOS sdk 中的 hdc.exe。

hdc_std.exe 在哪里?它在 OpenHarmony sdk 的 toolchains 目录下面,确保它和开发板上的版本一致,即确保 sdk 版本和开发板的操作系统版本匹配即可。

④自己编译 OpenHarmony SDK

为了确保 sdk 和自己烧写的操作系统版本一致,我们可以自己编译 sdk。

编译命令如下:

。/build.sh --product-name ohos-sdk --ccache

结果输出:

out/ohos-arm64-release/packages/ohos-sdk/

耗时了好久终于写完了,希望本文加上配上 OpenHarmony 官方的文档能够帮助更多的开发者快速投入 OpenHarmony 共建中。

责任编辑:haq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 操作系统
    +关注

    关注

    37

    文章

    7329

    浏览量

    128661
  • 鸿蒙系统
    +关注

    关注

    183

    文章

    2642

    浏览量

    69354
  • HarmonyOS
    +关注

    关注

    80

    文章

    2147

    浏览量

    35591
  • OpenHarmony
    +关注

    关注

    31

    文章

    3927

    浏览量

    20727

原文标题:HarmonyOS与OpenHarmony,区别很大!

文章出处:【微信号:gh_834c4b3d87fe,微信公众号:OpenHarmony技术社区】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    【汇思博SEEK100开发板试用体验】开发环境安装配置

    以下文字,基于SEEK100开发板试用经验,详细梳理OpenHarmony开发环境搭建的关键步骤与避坑要点: 一、开发工具部署:DevEco Studio精准安装 ​​核心版本选择​
    发表于 08-20 21:43

    HarmonyOS 5】金融应用开发鸿蒙组件实践

    HarmonyOS 5】金融应用开发鸿蒙组件实践 ##鸿蒙开发能力 ##HarmonyOS SDK应用服务##鸿蒙金融类应用 (金融理财# 一、鸿蒙生态观察 2024 年 1 月 1
    的头像 发表于 07-11 18:20 757次阅读
    【<b class='flag-5'>HarmonyOS</b> 5】金融应用<b class='flag-5'>开发</b>鸿蒙组件实践

    HarmonyOS 5 入门系列 】鸿蒙HarmonyOS示例项目讲解

    HarmonyOS 5 入门系列 】鸿蒙HarmonyOS示例项目讲解 ##鸿蒙开发能力 ##HarmonyOS SDK应用服务##鸿蒙金融类应用 (金融理财# 一、前言:移动
    的头像 发表于 07-07 11:57 811次阅读
    【 <b class='flag-5'>HarmonyOS</b> 5 入门系列 】鸿蒙<b class='flag-5'>HarmonyOS</b>示例项目讲解

    HarmonyOS入门指南

    1、文档与教程 HarmonyOS开发文档-应用开发导读 OpenHarmony--应用开发导读 仓颉编程语言官网 华为
    的头像 发表于 06-27 00:11 568次阅读

    华为正式启动HarmonyOS 6开发者Beta

    在2025年华为开发者大会(HDC)上,华为正式启动HarmonyOS 6开发者Beta,并全面展示一年多以来与合作伙伴共建鸿蒙生态的创新成果。
    的头像 发表于 06-24 15:42 647次阅读

    HarmonyOS 代码工坊的指尖开发,让 APP 开发所见即所得

    沙盘被直接搬入了移动设备本身。眼尖的开发者应该已经发现,最近华为应用市场“应用尝鲜”专区里,上架了一款名为“HarmonyOS 代码工坊”的新应用,下载量持续攀升。 开发者只需要下载“Harm
    的头像 发表于 06-24 12:08 643次阅读
    <b class='flag-5'>HarmonyOS</b> 代码工坊的指尖<b class='flag-5'>开发</b>,让 APP <b class='flag-5'>开发</b>所见即所得

    使用 Flutter SDK 3.27.4构建HarmonyOS应用

    使用 Flutter SDK 3.27.4构建HarmonyOS应用 下载鸿蒙版flutter(3.27.4版本) 项目地址:https://gitcode.com/openharmony
    的头像 发表于 06-11 09:15 739次阅读

    请问下,openharmony支持哪一款龙芯的开发板?有没有开源的龙芯的openharmony源码?

    想买个2k0300的开发板学习龙芯和openharmony,愣是没有看到提供openharmony源码的,也没与看到开源的代码。gitee上,openharmony的龙芯sig仓库也是
    发表于 04-26 13:06

    鸿蒙北向开发OpenHarmony5.0 DevEco Studio开发工具安装与配置

    本文介绍OpenHarmony5.0 DevEco Studio开发工具安装与配置,鸿蒙北向开发入门必备!由触觉智能Purple Pi OH鸿蒙开发板演示。搭载了瑞芯微RK3566四核
    的头像 发表于 03-28 18:05 1351次阅读
    鸿蒙北向<b class='flag-5'>开发</b><b class='flag-5'>OpenHarmony</b>5.0 DevEco Studio<b class='flag-5'>开发</b>工具安装与配置

    HarmonyOS 应用开发赋能套件:鸿蒙原生应用开发的 “神助攻”

    代码和开发实践等,这些问题让他们的开发工作容易走弯路。   为帮助开发者更高效地掌握HarmonyOS应用开发技能,官方推出了
    发表于 02-17 16:37

    鸿蒙北向开发OpenHarmony4.1 DevEco Studio开发工具安装与配置

    OpenHarmony4.1 DevEco Studio开发工具安装与配置,鸿蒙北向开发入门必备!
    的头像 发表于 02-07 17:35 1355次阅读
    鸿蒙北向<b class='flag-5'>开发</b><b class='flag-5'>OpenHarmony</b>4.1 DevEco Studio<b class='flag-5'>开发</b>工具安装与配置

    鸿蒙原生页面高性能解决方案上线OpenHarmony社区 助力打造高性能原生应用

    随着HarmonyOS NEXT的正式推出,鸿蒙原生应用开发热度高涨,数量激增。但在三方应用鸿蒙化进程中,性能问题频出。为此,HarmonyOS NEXT推出了一整套原生页面高性能解决方案,包括
    发表于 01-02 18:00

    AKI跨语言调用库神助攻C/C++代码迁移至HarmonyOS NEXT

    本帖最后由 HarmonyOS开发者社区 于 2025-1-3 15:41 编辑 随着HarmonyOS NEXT的发布,越来越多的应用加速推进鸿蒙化。在这一过程中,如何高效迁移原有资产、简化
    发表于 01-02 17:08

    HarmonyOS开发指导类文档更新速递(下)

    伴随着HarmonyOS 5.0.0 Release、HarmonyOS 5.0.1 Release版本的发布,HarmonyOS官网文档也带来了不少上新内容。本期HarmonyOS
    的头像 发表于 12-30 09:54 2153次阅读
    <b class='flag-5'>HarmonyOS</b><b class='flag-5'>开发</b>指导类文档更新速递(下)

    HarmonyOS开发指导类文档更新速递(上)

    伴随着HarmonyOS 5.0.0 Release版本的发布,HarmonyOS官网文档也带来了不少上新内容。本期HarmonyOS NEXT开发者资料直通车将从文档更新
    的头像 发表于 12-30 09:50 1769次阅读
    <b class='flag-5'>HarmonyOS</b><b class='flag-5'>开发</b>指导类文档更新速递(上)