百度收录网站之后又怎么做/惠州关键词排名提升

百度收录网站之后又怎么做,惠州关键词排名提升,网站怎么做sem优化,用路由器做简单的网站文章目录 鸿蒙OS架构设计探秘:从分层设计到多端部署一、鸿蒙的分层架构设计二、模块化设计的精髓三、智慧分发设计:资源的动态调度四、一次开发,多端部署的实践总结与思考 鸿蒙OS架构设计探秘:从分层设计到多端部署 最近两年来&a…

文章目录

  • 鸿蒙OS架构设计探秘:从分层设计到多端部署
    • 一、鸿蒙的分层架构设计
    • 二、模块化设计的精髓
    • 三、智慧分发设计:资源的动态调度
    • 四、一次开发,多端部署的实践
    • 总结与思考

鸿蒙OS架构设计探秘:从分层设计到多端部署

最近两年来,我一直在跟进鸿蒙系统的发展,从EMUI到HarmonyOS,见证了这个国产操作系统从无到有的成长历程。今天想和大家分享一下我对鸿蒙系统架构的理解和实践心得。

一、鸿蒙的分层架构设计

鸿蒙OS采用了一种独特的"1+8+N"分层架构,这和我们熟悉的Android、iOS有很大不同。这种架构让整个系统更加灵活,能更好地适应从智能手表到车机等不同设备。

从底层到上层,鸿蒙系统主要分为:

  1. 内核层:包括鸿蒙微内核、Linux内核和LiteOS
  2. 系统服务层:提供基础系统能力
  3. 框架层:为应用开发提供API
  4. 应用层:用户可见的应用程序

这种设计的最大优势在于"硬件下沉,应用上浮"。简单来说就是让硬件适配更简单,应用开发更统一。

来看一个调用系统服务的简单代码示例:

import systemParameter from '@ohos.systemparameter';// 获取系统参数示例
export default {getSystemInfo() {try {// 获取设备类型const deviceType = systemParameter.getSync("const.build.characteristics");console.info(`当前设备类型: ${deviceType}`);// 获取系统版本const osVersion = systemParameter.getSync("const.product.software.version");console.info(`系统版本: ${osVersion}`);return {deviceType, osVersion};} catch(error) {console.error(`获取系统参数失败: ${error.message}`);return null;}}
}

记得我刚开始接触这套架构时,还挺不习惯的,但用久了就发现,这种分层确实让跨设备开发更加一致。

二、模块化设计的精髓

鸿蒙系统的另一大亮点是其模块化设计思想。系统功能被拆分成一个个相对独立的"功能卡片",可以根据设备能力进行组合。

这让我想起微服务架构,只不过鸿蒙把这种思想应用到了操作系统级别。对我们开发者而言,最直观的体现就是Ability机制。

在HarmonyOS中,应用由一个或多个Ability组成,主要分为:

  • FA (Feature Ability): 带UI的Ability
  • PA (Particle Ability): 无UI的后台服务

看一个简单的Ability示例:

import Ability from '@ohos.application.Ability'export default class MainAbility extends Ability {onCreate(want, launchParam) {console.log("[Demo] MainAbility onCreate")// 能力创建时的初始化工作globalThis.abilityWant = want;}onDestroy() {console.log("[Demo] MainAbility onDestroy")}onWindowStageCreate(windowStage) {console.log("[Demo] MainAbility onWindowStageCreate")// 加载UI页面windowStage.loadContent('pages/index', (err, data) => {if (err.code) {console.error(`Failed to load content. Cause: ${JSON.stringify(err)}`)return}console.info("Succeeded in loading content.")})}// 其他生命周期方法...
}

我记得有次做一个跨设备项目时,这种模块化设计帮了大忙。同样的业务逻辑,只需要针对不同设备适配不同UI就行,省了不少工作量。

三、智慧分发设计:资源的动态调度

智慧分发可能是鸿蒙系统中最让我惊艳的部分。它能根据用户行为和设备状态,智能地分配系统资源,确保前台应用的流畅体验。

举个例子,当用户在玩游戏时,系统会自动为游戏分配更多计算资源;当接到重要通知时,系统会确保通知能及时展示。这种设计让整个系统感觉更"聪明"。

实现这一点的关键在于鸿蒙的分布式调度器。我们可以通过类似这样的代码来设置应用优先级:

import resourceSchedule from '@ohos.resourceschedule.resourceManager';// 申请重要前台任务优先级
try {// 创建资源使用信息let resourceRequest = {"resourceType": resourceSchedule.ResourceType.CPU,"resourceLevel": resourceSchedule.ResourceLevel.HIGH};// 申请资源resourceSchedule.applyResourceRequest(resourceRequest).then(() => {console.info('资源申请成功,开始执行重要计算任务');performHeavyTask();}).catch((err) => {console.error(`资源申请失败: ${err.message}`);});
} catch(error) {console.error(`操作异常: ${error}`);
}function performHeavyTask() {// 执行需要高CPU优先级的任务// ...// 任务完成后,释放资源resourceSchedule.releaseResourceRequest().then(() => {console.info('资源已释放');});
}

之前接触过一个项目,我们需要在多种设备上运行复杂的图像处理算法。通过智慧分发机制,我们实现了根据设备性能自动调整处理精度的功能,让用户体验更加一致。

四、一次开发,多端部署的实践

这可能是大多数开发者最关心的部分。鸿蒙系统承诺"一次开发,多端部署",那么实际效果如何呢?

从我这两年的经验来看,情况是这样的:框架确实提供了统一的开发范式,但要做到真正的一码多端,还需要不少额外工作。

鸿蒙使用ArkUI作为UI框架,支持声明式开发范式。它有点像React和Flutter的结合体,学习曲线不算陡峭。

看个响应式多端适配的例子:

@Entry
@Component
struct ResponsiveLayout {@State screenType: string = 'unknown';aboutToAppear() {// 获取设备信息并设置屏幕类型this.detectScreenType();}detectScreenType() {// 这里应该是根据设备实际尺寸判断const windowWidth = px2vp(window.innerWidth);if (windowWidth < 600) {this.screenType = 'phone';} else if (windowWidth < 1200) {this.screenType = 'tablet';} else {this.screenType = 'desktop';}}build() {Column() {Text(`当前设备类型: ${this.screenType}`).fontSize(20).margin(20)if (this.screenType === 'phone') {this.buildPhoneLayout()} else if (this.screenType === 'tablet') {this.buildTabletLayout()} else {this.buildDesktopLayout()}}.width('100%').height('100%')}@BuilderbuildPhoneLayout() {Column() {Text("手机布局").fontSize(18)// 手机专用组件布局}.width('100%')}@BuilderbuildTabletLayout() {Row() {Text("平板布局").fontSize(18)// 平板专用布局}.width('100%')}@BuilderbuildDesktopLayout() {Column() {Text("桌面布局").fontSize(18)// 桌面专用布局}.width('100%')}
}

总结与思考

经过几年发展,鸿蒙系统的架构设计已经变得相当成熟。分层架构提供了清晰的系统边界,模块化设计增强了系统灵活性,智慧分发机制优化了资源利用,而多端部署能力则大大提升了开发效率。

不过,作为一个从业多年的开发者,我也要实事求是地说,鸿蒙系统还有很长的路要走。特别是在生态建设方面,还需要吸引更多开发者参与。

最后想说,技术没有国界,但产品有祖国。鸿蒙的发展代表了中国在操作系统领域的一次重要突破,值得我们每一个开发者去了解和支持。

有什么问题欢迎在评论区讨论,我会尽量解答大家的疑问。下期我打算分享一下鸿蒙应用上架的那些坑,敬请期待!


你们觉得鸿蒙系统的哪个设计理念最吸引你?欢迎留言讨论~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/899152.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

idea 没有 add framework support(添加框架支持)选项

在 IntelliJ IDEA 2023 中&#xff0c;若需通过设置手动添加 “添加框架支持” 菜单项&#xff0c;可按照以下步骤操作&#xff1a; 手动添加 “添加框架支持” 菜单项 打开设置 点击顶部菜单栏的 File&#xff08;文件&#xff09; -> Settings&#xff08;设置&#xff09…

再探带权并查集

典型例题 Acwing 权值 故名思义&#xff0c;在带权并查集中&#xff0c;我们需要让每个节点携带一个**“权值”**。 那么这个权值应该是什么呢&#xff1f;其实答案就在并查集当中。 由于在并查集当中我们可以在 O ( 1 ) O(1) O(1) 时间内找到一个节点的根节点&#xff0c;那…

本地部署Stable Diffusion生成爆火的AI图片

直接上代码 Mapping("/send") Post public Object send(Body String promptBody) { JSONObject postSend new JSONObject(); System.out.println(promptBody); JSONObject body JSONObject.parseObject(promptBody); List<S…

边缘计算 vs. 云计算,谁才是工业物联网的未来?

前言 在物联网&#xff08;IoT&#xff09;飞速发展的今天&#xff0c;边缘计算正在彻底改变数据的处理、存储和分析方式。传统的IoT设备数据通常需要发送到云端进行处理&#xff0c;但随着设备数量的激增&#xff0c;这种模式在延迟、带宽和安全性方面暴露出诸多局限。边缘计…

dell 台式机 电脑 纽扣电池 如何取下?

dell 台式机 电脑 纽扣电池 如何取下&#xff1f; 戴尔-optiplex-3060-塔式机-服务手册

NFC 智能门锁全栈解决方案:移动端、服务器、Web 管理平台

目录 一、系统整体架构 二、移动端 APP 开发 2.1 开发环境与基础准备 2.2 主要功能模块 2.3 示例代码&#xff08;Android/Kotlin 简化示例&#xff09; 三、后台服务开发 3.1 环境准备 3.2 主要功能 3.3 示例代码&#xff08;Node.js Express 简化示例&#xff09; …

【AI】MAC版本本地Stable Diffusion web ui安装

文章目录 前言环境依赖homebrewpython3下载stable-diffusion-webui webui模型准备模型网站 中文页面设置提示词转汉语转英文controlnet安装controlnet模型下载 结尾 前言 目前&#xff0c;市面上已经出现了很多用Ai 绘图制作的作品&#xff0c;用于自媒体或者商业等。例如表情…

Linux 云服务器开放端口

首先找到你买服务器的官网&#xff0c;我这里是阿里云 点击这里的控制台 这里先点手动添加&#xff0c;再看自己是UDP还是TCP协议&#xff0c;找到对应的协议&#xff0c;目的就填你想开放的端口&#xff0c;源填所有IP/4 0.0.0.0 添加备注点击保存就开放好了。

[unity 点击事件] 区域响应点击事件,排除子节点区域,Raycast Target 应用

当我打开一个二级弹窗后&#xff0c;希望可以通过点击弹窗以外的区域来关闭该弹窗。一开始我是在弹窗主节点上挂载了一个 button 组件&#xff0c;该 button 注册的点击事件中关闭该弹窗。在子节点&#xff08;一个背景图&#xff09;的image组件上启用 Raycast Target 选项&am…

表的约束及代码练习

一.表的约束 查看表&#xff1a;mysql> select * from t_hero; 1.设置t_hero的主键为t_id alter table t_hero add primary key(t_id); 2.设置t_hero t_id属性非空 alter table t_hero modify t_id int not null;3.设置name属性为非空非重复 alter table t_hero modify…

Linux笔记---动静态库(使用篇)

目录 1. 库的概念 2. 静态库&#xff08;Static Libraries&#xff09; 2.1 静态库的制作 2.2 静态库的使用 2.2.1 显式指定库文件及头文件路径 2.2.2 将库文件安装到系统目录 2.2.3 将头文件安装到系统目录 3. 动态库 3.1 动态库的制作 3.2 动态库的使用 3.2.1 显式…

Java并发编程2(锁-Sychronized)

目录 认识Java对象头 sychronized锁原理 基本概念 工作原理 1.作用在方法上 2.作用在代码块上 工作机制 JVM优化锁 Monitor锁 wait/notify park/unpark 线程状态转换案例 死锁 概念 死锁发生的必要条件 哲学家问题 活锁 饥饿 概念 饥饿的原因 Reentrant…

现阶段高校的人工智能方案培训如何?

人工智能在未来肯定是核心发展力&#xff0c;核心竞争力&#xff0c;也是国家重点扶持的对象&#xff0c;但我还是不看好高校的人工智能方向&#xff0c;只是怕有些同学对市场前景盲目乐观&#xff0c;就轻易上车了。 你要是985以上的高校&#xff0c;可以考虑选择人工智能&…

JavaScript中的继承有哪些方式?各有什么优缺点

在 JavaScript 中&#xff0c;继承主要通过原型链实现&#xff0c;常见的继承方式有以下几种&#xff0c;每种方式都有其优缺点&#xff1a; 1. 原型链继承 1. 实现方式&#xff1a;将子类的原型对象指向父类的实例。 function Parent() {} function Child() {} Child.protot…

深入理解指针(3)(C语言版)

文章目录 前言 一、字符指针变量二、数组指针变量2.1 数组指针变量是什么2.2 数组指针变量怎么初始化2.2.1 静态初始化2.2.2 动态初始化 三、二维数组传参的本质四、函数指针变量4.1 函数指针变量的创建4.2 函数指针变量的使用4.3 typedef关键字4.4拓展 五、函数指针数组六、转…

csp信奥赛C++常用的数学函数详解

csp信奥赛C常用的数学函数详解 在信息学奥林匹克竞赛&#xff08;信奥赛&#xff09;中&#xff0c;C 的 <cmath> 头文件提供了丰富的数学函数&#xff0c;用于高效处理数学运算。以下是常用系统数学函数的详细讲解及汇总表格。 绝对值函数 int abs(int x)&#xff1a;返…

ChatDBA VS DeepSeek:快速诊断 OceanBase 集群新租户数据同步异常

社区王牌专栏《一问一实验&#xff1a;AI 版》改版以来已发布多期&#xff08;51-60&#xff09;&#xff0c;展现了 ChatDBA 在多种场景下解决问题的效果。 下面让我们正式进入《一问一实验&#xff1a;AI 版》第 62 期&#xff0c;看看 ChatDBA 最新效果以及与热门大模型 De…

oracle数据库(数据库启动关闭/sqlplus登录及基本操作/设置字符集/distinct去重)

目录 1. Oracle数据库启动 2. Oracle数据库关闭 3. sqlplus登录Oracle数据库 3.1 使用sqlplus登录Oracle数据库 3.2 使用sqlplus登录Oracle数据库 3.3 远程登录 3.4 解锁用户 3.5 修改用户密码 3.6 查看当前语言环境 4. sqlplus基本操作 4.1 显示当前用户 4.2 查看当前用户…

Java 大视界 -- Java 大数据在智能金融区块链跨境支付与结算中的应用(154)

&#x1f496;亲爱的朋友们&#xff0c;热烈欢迎来到 青云交的博客&#xff01;能与诸位在此相逢&#xff0c;我倍感荣幸。在这飞速更迭的时代&#xff0c;我们都渴望一方心灵净土&#xff0c;而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识&#xff0c;也…

在Cesium中使用ThreeJs材质(不是场景融合哦)

在Cesium中使用ThreeJs材质(不是场景融合哦&#xff09;_哔哩哔哩_bilibili