1.成为自己:鸿蒙 Harmony 工具篇
2.HarmonyOS NEXT应用开发之使用AKI轻松实现跨语言调用
3.初识鸿蒙跨平台开发框架ArkUI-X
4.OpenHarmony系统解决方案 - 配置屏幕方向导致开机动画和Launcher显示异常
5.华为自研编程语言“仓颉”来了!目源码a目鸿蒙应用开发新语言,源项性能优于 Java、目源码a目Go、源项Swift
6.海王星(Neptune)系列和大禹(DAYU)系列OpenHarmony智能硬件配置解决方案
成为自己:鸿蒙 Harmony 工具篇
华为鸿蒙系统新篇章:揭开开发者工具的目源码a目神秘面纱 自华为Mate和4.G芯片的崛起,鸿蒙Harmony系统引发了全球开发者热议。源项requirejs源码解析本文将深入解析鸿蒙开发的目源码a目每一个关键环节,带你走进HarmonyOS与OpenHarmony的源项世界。首先,目源码a目我们聚焦于开发者必备的源项工具,如主IDE DevEco-Studio,目源码a目它基于熟悉的源项IntelliJ,虽然Java开发者对其有所了解,目源码a目但还是源项有些许不同,安装时记得配置Node.js,目源码a目推荐长期维护版本。 管理大师:ohpm与SDK组件 ohpm,作为包管理工具,是安装和管理SDK组件的得力助手。HarmonyOS SDK包括API和实用工具,当前最高版本为3.1.0 API 9(商业版),与开源的OpenHarmony(不支持Java应用和模拟器)有着明确区分。两者之间的API和打包签名差异,将在后续章节详细讲解。 步入鸿蒙世界:开发框架与应用入门 以ArkTS为核心,鸿蒙的开发框架囊括了TypeScript编译器、后端支持和强大的调试器。ArkTS与ArkUI的集成,为开发者提供了声明式UI和高效的状态管理能力。学习之旅从创建首个鸿蒙移动端应用(Application)开始,DevEco IDE以Ability(类似Android的Activity)为入口,让开发者轻松跨越设备界限,实现跨设备开发。 工程结构与调试篇 遇到问题时,DevEco IDE的调试功能能帮助你找到答案。对于工程结构,IDE关注的是组件间的协作,而非编码风格统一。AppScope负责存储公共信息和资源,如app.json5,提供了兼容json5扩展特性的应用配置。entry模块则是初始化入口,存放页面源码和公共资源。 遇到技术挑战时,问题一:"ERROR: Cannot find module 'node:path'",升级Node.js至v..2以上版本,错误提示会得到修正。而问题二:MSG_ERR_INSTALL_FAILED_NO_BUNDLE_SIGNATURE,通过在Project Structure中生成签名,登录华为开发者账号,可以解决安装问题。至于问题三:Demo在鸿蒙4.0.0系统上的卡死问题,可能源于API兼容性,目前无明确解决方案,需关注后续更新。DW如何加载源码 打包阶段,Hap是Ability部署的关键,FA和PA是两种不同的部署方式。APP产物存放在ProjectRootDir/build/outputs/default,Hap产物则以.hap结尾,独立安装。同时,SDK管理、包管理以及调试工具如hdc和bytrace等,为开发者提供了全方位支持。 最后,务必注意使用sdkmgr时,确保你的Java版本在.0以上,否则可能会遇到无法使用的问题。总的来说,尽管Android与鸿蒙IDE基于IntelliJ有所关联,但语言、工具和编程模式的细微差别不容忽视。HarmonyOS NEXT应用开发之使用AKI轻松实现跨语言调用
针对跨语言访问场景,尤其是JS与C/C++之间的调用,NAPI的使用方式通常较为繁琐。而AKI(Application Kit Interface)则提供了简洁的语法糖,使开发者能够轻松实现JS与C/C++之间的无障碍跨语言互调,仅需一行代码即可完成调用。本示例将展示如何使用AKI实现C++跨线程调用JS函数的场景,具体而言,将通过调用C++的全局函数,并创建子线程来调用JS函数,实现对变量value的加操作。此示例旨在为开发者提供使用AKI进行跨语言调用的参考。
示例中展示了如何通过AKI和NPAI(Node Package API)的libuv实现跨线程调用JS函数的对比。以下是实现步骤的对比总结:
使用NAPI和libuv时,初始化需要定义`napi_property_descriptor`结构体,准备模块加载相关信息,并将`Init`函数与模块名等信息记录下来。在`hello.cpp`源码中,可以看到NAPI实现中在native侧的业务函数实现主要是在主线程中完成`UvWorkTest`接口,该接口接收ArkTS传入的JS回调函数后,创建子线程执行`CallbackUvWorkTest`函数。在该函数中,创建`workReq`任务,并通过`uv_queue_work`将任务添加到libuv队列中,等待执行。在`Index.ets`源码中,可以看到ArkTS侧调用C++全局函数`UvWorkTest`的实现。
通过对比,可以明显看出使用AKI相较于NAPI在native侧的代码量更少,实现方式更为直观和方便。
此外,高性能知识点、工程结构、模块类型、模块依赖等技术细节在实际项目中同样重要,这些内容通常需要根据项目需求和具体实现策略进行深入探讨和实践,vue项目cms源码以确保代码的高效执行和良好的维护性。
初识鸿蒙跨平台开发框架ArkUI-X
HarmonyOS,面向万物互联时代,提供全场景业务能力。 ArkTS,华为自研语言,匹配 ArkUI 框架,简化跨端应用开发。 ArkUI-X,扩展 ArkUI 支持,实现多 OS 平台开发,包括 OpenHarmony、HarmonyOS、Android、iOS。环境搭建
安装 DevEco Studio,支持 ArkUI-X,版本需4.0以上,下载链接提供。 Android Studio用于打包,下载地址附上。 构建 iOS 环境,Xcode等安装略。OpenHarmony SDK 安装
DevEco Studio启动提示安装 Node,HarmonyOS 应用支持 JS 开发,按提示安装即可。 设置 OpenHarmony SDK,类似于 Android 的 SDK,配置路径。ArkUI-X SDK 安装
安装 ArkUI-X SDK,在设置中选择并指定路径。环境变量配置
设置环境变量,添加 Android SDK 路径,Windows 和 macOS 配置方法提供。快速上手
创建普通 Harmony OS 工程,按照提示配置。 对比 HarmonyOS 和 OpenHarmony,选择导入 OpenHarmony 及 ArkUI-X 的 HelloWorld 示例。 下载源码,导入 OpenHarmony 工程,预览界面。代码移入与编译
将 Harmony OS 工程的 UI 代码移入 OpenHarmony 工程,替换对应文件。 预览并运行 OpenHarmony 工程,显示已创建界面。编译与运行
打开 OpenHarmony 工程,编译为 OpenHarmony、Android、iOS 项目。 使用 Android Studio 或 Xcode 运行或打包应用。应用工程结构
跨平台应用工程包含 ArkUI 开发者模板,支持构建不同平台应用。 理解 OpenHarmony 应用工程编译构建,涉及 ArkTS 和资源管理。html下载按钮源码 讨论 Android 和 iOS 应用工程结构,关注原生应用工程。总结
ArkTS + ArkUI-X 跨平台开发框架提供国产自研技术,简化多平台应用开发。 链接提供相关代码和参考资料。OpenHarmony系统解决方案 - 配置屏幕方向导致开机动画和Launcher显示异常
系统版本:OpenHarmony-3.2-Release 遇到的问题是配置屏幕方向导致开机动画和Launcher显示异常。 问题现象出现在源码文件foundation/window/window_manager/resources/config/rk/display_manager_config.xml和系统文件/etc/window/resources/display_manager_config.xml中。 异常效果是:正常效果下,系统运行平稳,无异常表现。 问题的原因在于ScreenRotationController初始化时序的不当,使ScreenRotationController在Launcher加载Window时未触发。 解决办法是调整ScreenRotationController的初始化时序,确保在Launcher加载Window时触发。通过修改源码文件foundation/window/window_manager/wmserver/src/window_node_container.cpp,对WindowNodeContainer::RemoveWindowNode和WindowNodeContainer::AddWindowNode函数进行代码修改。 在定位问题的过程中,我们了解到若应用方向需要随系统切换,可在module.json5的ability中配置orientation为auto_rotation_restricted。 为帮助大家更好地学习鸿蒙 (OpenHarmony) 开发技术,特别整理了《鸿蒙 (OpenHarmony)开发学习手册》(共计页),旨在提供深入学习资源。 以下为手册的入门指南:《鸿蒙 (OpenHarmony)开发学习手册》入门必看:qr.cn/FV7h
HarmonyOS 概念:qr.cn/FV7h
如何快速入门?:qr.cn/FV7h
开发基础知识:qr.cn/FV7h
基于ArkTS 开发:qr.cn/FV7h
手册覆盖了以下鸿蒙 (OpenHarmony) 开发领域:Ability开发
UI开发
公共事件与通知
窗口管理
媒体
安全
网络与链接
电话服务
数据管理
后台任务(Background Task)管理
设备管理
设备使用信息统计
DFX
国际化开发
折叠屏系列
……
华为自研编程语言“仓颉”来了!鸿蒙应用开发新语言,性能优于 Java、Go、Swift
仓颉编程语言,华为自主研发的国产自主编程语言,于HDC 正式发布,旨在为开发者提供友好开发体验和卓越程序性能。随着万物互联和智能时代的到来,软件开发对编程语言提出了新的需求。仓颉语言面向全场景应用开发,拥有现代语言特性的集成、全方位的编译优化和运行时实现,以及开箱即用的IDE工具链支持,是专为智能化、端边云协同等新场景设计的下一代编程语言。
当前,鸿蒙原生应用开发中,广泛使用了支持声明式UI和一次开发、多端部署的ArkTS语言。仓颉语言作为面向未来的编程语言,已完成设计与实现,并启动了开发者预览,未来将与ArkTS共同发展,为开发者提供极致高效的开发体验。
仓颉编程语言填补了国产编程语言的空白,当前中国开发者使用的主流编程语言主要为Java、JavaScript、Python等,这些语言大多由国外厂商及科研机构把控。在全球编程语言发展水平的高地,主要集中在欧洲和美国。依赖spring源码模块丹麦、荷兰、瑞士等国家在编程语言领域有重要贡献。值得注意的是,在当前复杂的国际形势下,多数主流编程语言可能存在断供风险,例如Java和Go语言的主导性和控制性。
构建编程语言周期长,挑战大。国内尚无规模商用的自研编程语言,国产编程语言稀缺,仅有Go语言的爱好者发起的凹语言、Go+语言、易语言、MoonBit等。国产编程语言的自主可控成为工业和信息化部十四五规划的一项重点工作。
仓颉编程语言定位为现代编程语言,主打高效编程、安全可靠、轻松并发、卓越性能、敏捷扩展,设计时在安全性、易用性和性能之间进行了权衡。它选择居于动态脚本语言和系统编程语言之间,被设计为具备自动内存管理功能、静态类型、面向应用开发的语言,注重“语法简洁低噪音,且能面向领域易扩展”,在性能上注重“垂直整合、性能可伸缩、稳定可预期”,在安全上注重“缺省模式安全、强化编译期安全约束”。
仓颉编程语言在性能上取得了明显优势,在计算机语言基准测试Benchmarks Game上表现优秀。它还支持面向应用开发的一系列工具链,包括语言服务、调试、静态检查、性能分析、包管理、文档生成、Mock工具、测试框架、覆盖率工具、Fuzz工具以及智能辅助编程工具,进一步提升软件开发体验以及效率。
仓颉编程语言特性完备,支持函数式、命令式和面向对象等多种编程范式,包括值类型、类和接口、泛型、代数数据类型、模式匹配、以及高阶函数等特性。它还支持类型推断,降低开发者类型标注的负担,通过一系列简明高效的语法减少冗余书写,提升开发效率,内置语法糖和宏的能力支持开发者快速开发领域专用语言(DSL),构建领域抽象。
仓颉编程语言提供了多方面技术特色,包括函数是一等公民、高效并发、轻量化线程模型、跨语言互操作和原生智能化。其中,仓颉的线程采用M:N线程模型,是用户态的轻量级线程,支持抢占,内存资源占用更小,轻松实现数千甚至数万个并发任务。仓颉还支持与C、ArkTS/JS、Python等编程语言的互操作,采用便捷的声明式编程范式实现对其他语言库的高效复用和生态兼容。仓颉编程语言通过调试器cjdb提供源码级调试能力,支持跨语言调试,最大程度上提升用户调试体验。
仓颉编程语言正在构建AI原生能力,提供原生AI能力简化开发难度,AI相关功能如模型部署、智能决策等成为语言表达力的一部分,带来高效的开发体验。仓颉团队正尝试构建Agent DSL,一种专为AI Agent开发和多Agent协同设计的领域特定语言,提供内嵌在仓颉语言中的DSL能力,使开发者无需额外学习复杂的库和框架,通过DSL简单直观地使用AI功能。
仓颉编程语言还构建了原生AI应用框架,与语言原生配合给开发者带来全场景智能化时代的应用编程新体验。仓颉团队正在构建的AI赋能能力,希望通过简洁的语法表达降低开发者编写AI应用的门槛,提升AI应用开发的效率,使代码更精准地对应AI Agent的操作、决策过程。
海王星(Neptune)系列和大禹(DAYU)系列OpenHarmony智能硬件配置解决方案
海王星(Neptune)系列和大禹(DAYU)系列OpenHarmony智能硬件配置解决方案,通过规范的目录树规则和源码路径规则,为产品适配、部件拼装、启动配置和文件系统配置提供指导。产品解决方案的源码路径规则定义为:vendor/{ 厂商名}/{ 产品名}_。新增产品时,必须遵循此规则建立目录与文件,以供编译构建系统扫描配置。 解决方案的目录结构遵循明确的规则,确保系统能有效识别并处理产品配置。关键目录与文件的详细说明如下,fs.yml文件为可选配置项,适用于有文件系统的设备。 产品配置过程支持灵活的芯片解决方案与部件拼装,形成定制化解决方案。此流程包括验证产品字段的有效性,确保与已知芯片解决方案匹配,以及与部件描述相符。配置完成后,通过编译构建系统,并使用--patch参数,将配置文件集成至产品目录中,以进行后续编译。 特别推荐《鸿蒙开发学习手册》(共计页),为学习鸿蒙(HarmonyOS NEXT)开发技术提供全面指导。手册覆盖应用开发、基础知识、ArkTS语言、开发实践及面试题等内容,帮助开发者深入理解HarmonyOS的架构与开发方法。 手册内容包括: 应用开发导读(ArkTS) HarmonyOS概念介绍 开发基础知识:应用基础知识、配置文件、应用数据管理、应用安全管理、应用隐私保护、三方应用调用管控机制、资源分类与访问、ArkTS语言学习 基于ArkTS的开发实践:Ability开发、UI开发、公共事件与通知、窗口管理、媒体、安全、网络与链接、电话服务、数据管理、后台任务管理、设备管理、设备使用信息统计、DFX、国际化开发、折叠屏应用开发 面试真题及答案,涵盖HarmonyOS开发的核心知识点纯血鸿蒙也是运行jvm吗
纯血鸿蒙不再运行JVM,而是采用了自研的运行时环境来支持其新的编程语言ArkTS。这一变化是鸿蒙系统自主化、高效化以及全场景智能生态建设的一部分。纯血鸿蒙也是运行jvm吗
答:纯血鸿蒙系统将不再运行JVM虚拟机。
一、鸿蒙系统的技术基础与发展
1、剔除安卓代码:鸿蒙NEXT的核心变化是在系统层面剔除了Linux内核和AOSP(Android开放源代码项目)的代码。这意味着鸿蒙从系统层面不再兼容和支持Android应用,自然也包括了基于Java的语言和JVM。
2、全栈自研:鸿蒙系统通过全栈自研,包括操作系统内核、文件系统、编程语言、编译器/运行时等,实现了高度自主控制。这使得鸿蒙系统不再依赖Java平台和JVM。
二、纯血鸿蒙的编程语言与环境
1、ArkTS语言:纯血鸿蒙应用主要使用ArkTS语言进行开发。ArkTS是基于TypeScript的超集,专为鸿蒙系统设计,用以替代传统的Java开发模式。
2、放弃Java语言:鸿蒙系统在API8及之后的版本中官方不再支持使用Java语言进行应用开发。这一变化减少了对JVM的依赖,使鸿蒙系统能够发展自己的运行环境。
三、鸿蒙原生智能架构与生态
1、AI能力整合:鸿蒙NEXT版本强化了AI能力,通过将华为的AI技术下沉到系统层面,为三方应用提供更加智能化的体验。这种整合无需依赖于JVM,而是利用鸿蒙自己的运行时环境。
2、多场景应用开发:鸿蒙系统鼓励开发者使用其自研的编程框架和运行时进行应用开发,从而摆脱对Java和JVM的依赖。
OpenAtom OpenHarmony三方库创建发布及安全隐私检测
OpenAtom OpenHarmony 三方库(简称“三方库”或“包”),是经过验证可在 OpenHarmony 系统上重复使用的软件组件,助力开发者快速开发 OpenHarmony 应用。三方库分为两类:一类是使用 JavaScript 和 TypeScript 的三方库,通过源码或 OpenHarmony HAR/HSP 引入;另一类是 C 和 C++ 语言的三方库,通过 N-API 暴露 JS 接口或编译在操作系统中使用。 鼓励开发者通过 OpenHarmony 三方库中心仓分享三方库,促进开源资源的利用和应用生态的繁荣。本文将介绍三方库的创建、发布与安全隐私检测。三方库创建与发布
创建三方库
创建 OpenHarmony 三方库,支持 IDE 和 OHPM 命令行两种方式。通过 IDE 创建,选择“Static Library”模板,完善 oh-package.json5 的信息。命令行创建需参照三方中心仓指导文档操作。编译与打包
完成后,通过 DevEco Studio 编译构建,生成 HAR/HSP,用于其他模块引用或上传至 OHPM 平台。配置 .ohpmignore 文件可忽略打包文件。发布三方库
发布前确保删除敏感信息。配置 OHPM 公钥,完成发布,发布成功后,平台将通知审核进度。三方库安全隐私检测
安全是核心原则,三方库通过自动化工具扫描和人工审核检测。工具扫描包含完整性与安全性检查,识别恶意行为。人工复审测试功能实现,确保三方库无漏洞和功能问题。工具扫描
包括完整性与安全性检查,识别风险类型,如安全漏洞、权限滥用、网络连接、数据跨境、内容合规、个人数据搜集等,确保三方库安全。人工复审
测试三方库功能,确保其在 OpenHarmony 上验证有效。未实现功能或无法验证的三方库将被退回。 为了帮助开发者学习鸿蒙 (Harmony OS) 开发技术,提供了《鸿蒙 (Harmony OS)开发学习手册》资源,内容覆盖入门、概念、快速入门、基础知识、ArkTS 开发等,希望对学习有所帮助。HarmonyOS—使用预览器查看应用/服务效果
DevEco Studio提供UI预览功能,方便开发者实时查看应用/服务的UI界面效果,便于随时调整布局。预览器支持实时预览和动态预览,适应多种设备,包括Phone、Tablet、TV和Wearable。开发者可使用预览器在不同设备上预览JS、ArkTS和Java应用/服务,实现布局、交互效果的实时查看。需要注意的是,预览效果可能与真机设备运行存在差异,仅供参考。建议升级至最新版本的DevEco Studio和SDK,以获取最佳体验。使用预览器时,应确保源代码保存,以便实时查看应用/服务效果。开发者还需注意预览器的限制,如组件预览的设备属性、不支持某些组件和库的预览等。通过配置文件调整预览设备属性,以适应不同设备需求。DevEco Studio还提供Profile Manager功能,自定义预览设备,支持多设备同时预览,方便开发者在开发过程中查看应用/服务在不同设备上的效果。使用多端设备预览时,需注意设备类型和编码语言的兼容性。双向预览功能实现代码编辑器、UI界面和组件树间的联动,提升开发效率。在预览界面修改属性或样式后,UI界面会自动同步更新,反之亦然,但存在数据绑定和动画效果的限制。
鸿蒙4.0模拟器的中文输入的解决方法
鸿蒙4.0模拟器的中文输入问题可以通过安装第三方输入法来解决。在使用DevEco Studio 3.1时,如果内置的模拟器不支持中文输入,开发人员需要在模拟器上安装额外的输入法。一个推荐的解决方案是安装瘦狗提供的sougoushurufaxban_.apk版本,这个输入法可以满足在HarmonyOS应用开发过程中输入汉字的需求。通过这个输入法,开发者可以流畅地进行中文输入,提高开发效率。
DevEco Studio作为集成开发环境,提供了动态共享包HSP功能,以减少包体积和共享公共资源,对于大型企业应用开发尤为有利。它还支持闭源HAR构建,保护源代码的同时方便组件和资源共享。同时,它支持多语言开发,包括ArkTS、JS和C/C++,并具备代码自动补全、实时错误检查和智能跳转功能,有助于提升编码质量。
对于开发者调试HarmonyOS应用,DevEco Studio提供了本地和远程模拟器选项,适应不同设备类型。特别是远程超级终端模拟器,支持跨设备应用的调试。ArkTS和ArkUI则为高效开发提供了类型约束、声明式UI和丰富的UI工具,使得应用开发更为简洁和高效。
通过参加黑马训练营和《传智教育鸿蒙技能大赛》项目,开发者不仅能学习鸿蒙生态的知识,还能在实际项目中解决具体问题,如中文输入的配置。总之,DevEco Studio 3.1提供了全面的开发工具和环境,帮助开发者顺利应对各种挑战,包括解决中文输入问题。