当前位置: 首页 > article >正文

HarmonyOS NEXT个人开发经验总结

在这里插入图片描述

文章目录

    • 1. 开发环境配置
      • 1.1 工具链安装流程
      • 1.2 环境配置代码
    • 2. 项目架构设计
      • 2.1 分层架构图
      • 2.2 模块化配置
    • 3. 核心开发实践
      • 3.1 声明式UI开发
      • 3.2 分布式数据管理
    • 4. 性能优化策略
      • 4.1 性能优化流程图
      • 4.2 优化实践代码
    • 5. 安全与权限管理
      • 5.1 权限申请流程
      • 5.2 安全存储示例
    • 6. 测试与调试
      • 6.1 测试金字塔
      • 6.2 单元测试示例
    • 7. 部署与发布
      • 7.1 发布流程
      • 7.2 构建配置
    • 8. 经验总结
      • 8.1 最佳实践
      • 8.2 常见问题

1. 开发环境配置

1.1 工具链安装流程

下载DevEco Studio
安装SDK
配置模拟器
创建项目
运行调试

1.2 环境配置代码

# 安装命令行工具
npm install -g @ohos/hvigor# 创建NEXT项目
hvigor init --template @ohos/next-ts# 配置环境变量
export HARMONY_HOME=/path/to/sdk
export PATH=$PATH:$HARMONY_HOME/tools

2. 项目架构设计

2.1 分层架构图

设备服务层
数据访问层
业务逻辑层
UI层
硬件抽象
驱动接口
安全服务
本地存储
分布式数据
网络请求
Ability管理
服务编排
任务调度
ArkUI组件
声明式布局
状态管理
UI层
业务逻辑层
数据访问层
设备服务层

2.2 模块化配置

// oh-package.json
{"name": "myapp","version": "1.0.0","dependencies": {"@ohos/distributedData": "^1.0.0","@ohos/securityEngine": "^1.0.0"},"devDependencies": {"@ohos/hvigor": "^2.0.0","@ohos/unitTest": "^1.0.0"}
}

3. 核心开发实践

3.1 声明式UI开发

@Entry
@Component
struct MainPage {@State private count: number = 0;@State private listData: string[] = [];build() {Column() {Text('Hello HarmonyOS NEXT').fontSize(24).fontWeight(FontWeight.Bold)Button('Click Me').onClick(() => this.count++).margin(10)LazyForEach(this.listData, (item: string) => {ListItem() {Text(item).fontSize(16)}}, (item: string) => item)}.width('100%').height('100%').onAppear(() => this.loadData())}private loadData() {// 模拟异步加载setTimeout(() => {this.listData = Array.from({length: 100}, (_, i) => `Item ${i + 1}`);}, 1000);}
}

3.2 分布式数据管理

import distributedData from '@ohos.data.distributedData';class DataManager {private kvStore: distributedData.KVStore;async init() {const kvManager = distributedData.createKVManager({bundleName: 'com.example.myapp',options: {securityLevel: distributedData.SecurityLevel.S2}});this.kvStore = await kvManager.getKVStore('appData', {createIfMissing: true,encrypt: true,autoSync: true});}async saveData(key: string, value: any) {await this.kvStore.put(key, JSON.stringify(value));}async getData<T>(key: string): Promise<T | null> {const value = await this.kvStore.getString(key);return value ? JSON.parse(value) : null;}
}

4. 性能优化策略

4.1 性能优化流程图

启动优化
内存管理
渲染优化
网络优化
存储优化
持续监控

4.2 优化实践代码

// 使用对象池
class ObjectPool<T> {private pool: T[] = [];private creator: () => T;constructor(creator: () => T) {this.creator = creator;}acquire(): T {return this.pool.pop() || this.creator();}release(obj: T) {this.pool.push(obj);}
}// 图片懒加载
@Component
struct LazyImage {@State private isLoaded: boolean = false;private imageSource: image.ImageSource;build() {Image(this.isLoaded ? this.imageSource : 'placeholder.png').onAppear(() => this.loadImage())}private loadImage() {image.createImageSource('https://example.com/image.jpg').then(src => {this.imageSource = src;this.isLoaded = true;});}
}

5. 安全与权限管理

5.1 权限申请流程

App System User 检查权限状态 返回已授权 显示权限申请弹窗 选择授权 返回授权结果 alt [已授权] [未授权] App System User

5.2 安全存储示例

import securityEngine from '@ohos.securityEngine';
import dataPreferences from '@ohos.data.preferences';class SecureStorage {private static instance: SecureStorage;private kvStore: dataPreferences.Preferences;private constructor() {}static async getInstance(): Promise<SecureStorage> {if (!this.instance) {this.instance = new SecureStorage();await this.instance.init();}return this.instance;}private async init() {const keyAlias = 'secure_storage_key';await securityEngine.generateAsyKey(keyAlias, {algName: securityEngine.AsyKeyAlgName.RSA_2048,purpose: securityEngine.KeyPurpose.ENCRYPT | securityEngine.KeyPurpose.DECRYPT,isPersistent: true});this.kvStore = await dataPreferences.getPreferences({name: 'secure_data',encryptConfig: {encryptKey: keyAlias,securityLevel: securityEngine.SecurityLevel.S3}});}async setItem(key: string, value: string) {await this.kvStore.put(key, value);await this.kvStore.flush();}async getItem(key: string): Promise<string | null> {return await this.kvStore.get(key, null);}
}

6. 测试与调试

6.1 测试金字塔

UI测试
集成测试
单元测试

6.2 单元测试示例

import { describe, it, expect } from '@ohos/hypium';describe('MathUtils', () => {it('add_test', 0, () => {expect(MathUtils.add(1, 2)).assertEqual(3);});it('async_test', 0, async () => {const result = await fetchData();expect(result).assertDeepEquals(expected);});
});

7. 部署与发布

7.1 发布流程

代码提交
CI构建
测试验证
签名打包
发布审核
上架应用市场

7.2 构建配置

// hvigorfile.ts
export default {projects: {entry: {compileMode: 'release',signingConfig: {storeFile: 'release.keystore',storePassword: '******',keyAlias: 'release',keyPassword: '******'},buildTypes: {release: {minifyEnabled: true,proguardFiles: ['proguard-rules.pro']}}}}
}

8. 经验总结

8.1 最佳实践

  1. 组件化设计:保持高内聚低耦合
  2. 状态管理:合理使用@State和@Prop
  3. 性能优化:关注内存和渲染性能
  4. 安全规范:遵循最小权限原则

8.2 常见问题

问题解决方案
UI卡顿使用LazyForEach优化列表
减少布局嵌套层级
内存泄漏使用WeakRef管理引用
及时释放资源
跨设备通信失败检查网络连接
确认设备认证状态

通过本文的系统总结,开发者可以全面掌握HarmonyOS NEXT的开发流程与最佳实践。建议结合实际项目需求,灵活运用各项技术,构建高质量的分布式应用。
在这里插入图片描述

相关文章:

HarmonyOS NEXT个人开发经验总结

文章目录 1. 开发环境配置1.1 工具链安装流程1.2 环境配置代码 2. 项目架构设计2.1 分层架构图2.2 模块化配置 3. 核心开发实践3.1 声明式UI开发3.2 分布式数据管理 4. 性能优化策略4.1 性能优化流程图4.2 优化实践代码 5. 安全与权限管理5.1 权限申请流程5.2 安全存储示例 6. …...

Python基于深度学习的多模态人脸情绪识别研究与实现

一、系统架构设计 A[数据采集] --> B[预处理模块] B --> C[特征提取] C --> D[多模态融合] D --> E[情绪分类] E --> F[系统部署] F --> G[用户界面] 二、数据准备与处理 1. 数据收集 - 视频数据&#xff1a;FER2013&#xff08;静态图像&#xff0…...

golang快速上手基础语法

变量 第一种&#xff0c;指定变量类型&#xff0c;声明后若不赋值&#xff0c;使用默认值0 package mainimport "fmt"func main() {var a int //第一种&#xff0c;指定变量类型&#xff0c;声明后若不赋值&#xff0c;使用默认值0。fmt.Printf(" a %d\n"…...

【MySQL】多表操作 —— 外键约束

目录 多表关系一对一关系一对多/多对一关系多对多关系 外键约束基本概念一对多/多对一创建外键约束外键约束下的数据操作数据插入数据删除 删除外键约束 多对多创建外键约束外键约束下的数据操作数据插入数据删除 删除外键约束 多表关系 MySQL 多表之间的关系可以概括为&#…...

⭐算法OJ⭐两数之和【哈希表】(C++ 实现)Two Sum

“两数之和”&#xff08;Two Sum&#xff09;是一道非常经典的算法题目&#xff0c;几乎是算法入门和面试准备的必做题之一。它的经典性体现在以下几个方面&#xff1a; 1. 算法入门的基础题目 这道题目是许多初学者接触 哈希表&#xff08;Hash Table&#xff09; 或 字典&…...

从被动响应到主动预见:智能可观测性技术的变革与实践

思维导图 一、引言 🌃 想象一下,在一个深夜 🌙,你的关键业务系统突然出现故障 🚨。传统情况下,你可能会收到大量不相关的告警 📱💬💬💬,然后花费数小时甚至数天时间 ⏳,在错综复杂的系统架构中寻找根本原因 🔍。而在智能可观测性的世界里,故障发生前系统…...

【GPT入门】第22课 langchain LCEL介绍

【GPT入门】第22课 langchain LCEL介绍 1. LCEL介绍与特点2. 原生API与LCEL的对比2. 简单demo 1. LCEL介绍与特点 LCEL 即 LangChain Expression Language&#xff0c;是 LangChain 推出的一种声明式语言&#xff0c;用于简化和优化在 LangChain 框架内构建复杂链和应用的过程…...

LeetCode1005☞K次取反后最大的数组和

关联LeetCode题号1005 本题特点 贪心&#xff1a;局部最优解&#xff1a;将负数取反得到比原值大的值&#xff0c;进而全局最优解整体和为最大二次贪心: 如果取反次数大于负数个数&#xff0c;那么剩下次数如果为奇数&#xff0c;那么就将绝对值最小的数取反&#xff08;贪心…...

7、基于osg引擎实现读取vtk数据通过着色器实现简单体渲染(1)

基于光线投射原理实现的体渲染 一、什么是体绘制&#xff1f;二、为什么不直接用3D模型渲染三、原理及部分代码解析1、什么是光线&#xff1f;2、什么是光线投射&#xff1f;3、为什么需要光线投射3D纹理&#xff1f;4、为什么必须是3D纹理&#xff1f;5、为什么还需要1D纹理&a…...

二、vtkCommand的使用

一、概述 vtkCommand是VTK中的一个重要的类&#xff0c;用于处理事件和回调机制。它允许用户在特定事件发生时执行自定义的操作&#xff0c;例如在交互操作、数据更新或渲染过程中触发某些功能。 二、主要功能 1、事件处理&#xff1a;vtkCommand用于监听和处理VTK管线中的各…...

Git的详细使用方法

Git 是一个分布式版本控制系统&#xff0c;用于跟踪和管理代码的变更。以下是 Git 的详细使用方法&#xff1a; 1. 安装 Git Windows&#xff1a;从 Git 官网 下载安装包。 Linux&#xff08;Ubuntu/Debian&#xff09; sudo apt install git macOS&#xff1a; 使用 Homebr…...

在 Windows 上使用 choco 安装 mkcert 并配置 Vue 运行HTTPS

解决在Windows上使用Vue本地运行HTTPS的问题,vue-cli或vite都可以使用 步骤 1&#xff1a;确认 Chocolatey 是否已安装 1. 检查 choco 命令是否可用 打开 PowerShell&#xff08;管理员权限&#xff09;&#xff0c;输入&#xff1a; choco -v如果显示版本号&#xff08;如…...

spring声明式事务原理01-调用第1层@Transactional方法(事务访问入口)

文章目录 【README】【步骤1】UserAppService调用userSupport.saveNewUser()【步骤2】获取到TransactionInterceptor【步骤3】chain不为空&#xff0c;接着执行CglibMethodInvocation#proceed方法【补充】AopContext作用 【步骤4】CglibMethodInvocation#proceed方法【步骤5】调…...

Qt-D指针与Q指针的设计哲学

文章目录 前言PIMLP与二进制兼容性D指针Q指针优化d指针继承Q_D和Q_Q 前言 在探索Qt源码的过程中会看到类的成员有一个d指针&#xff0c;d指针类型是一个private的类&#xff0c;这种设计模式称为PIMPL&#xff08;pointer to implementation&#xff09;&#xff0c;本文根据Q…...

数据结构——单链表list

前言&#xff1a;大家好&#x1f60d;&#xff0c;本文主要介绍数据结构——单链表 目录 一、单链表 二、使用步骤 1.结构体定义 2.初始化 3.插入 3.1 头插 3.2 尾插 3.3 按位置插 四.删除 4.1头删 4.2 尾删 4.3 按位置删 4.4按值删 五 统计有效值个数 六 销毁…...

java 的标记接口RandomAccess使用方法

在 Java 中&#xff0c;RandomAccess 是一个标记接口&#xff08;marker interface&#xff09;&#xff0c;用于标识实现该接口的 List 实现类支持快速&#xff08;通常是常数时间复杂度 O(1)&#xff09;的随机访问。常见的实现类包括 ArrayList&#xff0c;而不包括 LinkedL…...

基于PHP的网店进销存管理系统(源码+lw+部署文档+讲解),源码可白嫖!

摘要 相比于以前的传统进销存管理方式&#xff0c;智能化的管理方式可以大幅降低进销存管理的运营人员成本&#xff0c;实现了进销存管理的标准化、制度化、程序化的管理&#xff0c;有效地防止了商品信息及仓库信息的随意管理&#xff0c;提高了信息的处理速度和精确度&#…...

Vue3 Pinia $subscribe localStorage的用法 Store的组合式写法

Vue3 Pinia $subscribe 可以用来监视Stroe数据的变化 localStorage的用法 localStorage中只能存字符串&#xff0c;所有对象要选转成json字符串 定义store时&#xff0c;从localStorage中读取数据talkList可能是字符串也可能是空数组 Store的组合式写法 直接使用reactiv…...

【PHP】获取PHP-FPM的状态信息

文章目录 一、前言二、环境三、过程1&#xff09;修改PHP-FPM配置文件2&#xff09;修改Nginx配置文件3&#xff09;访问页面4&#xff09;修改状态页面端口 一、前言 PHP-FPM内置有一个状态页面&#xff0c;通过这个页面可以获取到FPM的一些状态信息&#xff08;见下图&#…...

(性能测试)性能测试工具 2.jmeter的环境搭建 3jmeter元件和4使用实例 5jmeter元件和参数化

目录 性能测试工具 性能测试工具 jemeter环境搭建 jmeter的常用目录介绍 jmeter修改语言和主题--jmeter界面的汉化 jmeter元件 jmeter元件和组件的介绍 jmeter的作用域原则 jmeter的执行顺序 案例&#xff1a;执行顺序 jmeter使用案例 jmeter线程组的介绍 jmeter…...

Java 大视界 -- 基于 Java 的大数据实时流处理中的窗口操作与时间语义详解(135)

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

数据库的基本知识

目录 一、创建数据库和数据表1.1 创建数据库相关代码1.2 创建数据表1.3 约束条件1.3.1 主键约束1.3.2 非空约束1.3.3 唯一性约束1.3.4 默认约束1.3.5 自增字段 1.4 手工建表 二、数据查询功能2.1 sql 查询的7个关键词2.1.1 select2.1.2 from2.1.3 where2.1.4 group by2.1.5 hav…...

失败的面试经历(ʘ̥∧ʘ̥)

一.面向对象的三大特性 1.封装&#xff1a;将对象内部的属性私有化&#xff0c;外部对象不能够直接访问&#xff0c;但是可以提供一些可以使外部对象操作内部属性的方法。 2.继承&#xff1a;类与类之间会有一些相似之处&#xff0c;但也会有一些异处&#xff0c;使得他们与众…...

【Jmeter】使用教程

下载及安装 参考链接: JMeter下载及安装&#xff08;附插件及中文包超详细&#xff09; 参考链接: 【Jmeter】win 10 / win 11&#xff1a;Jmeter 下载、安装、汉化、新机迁移、版本更新&#xff08;Jmeter 4 以上版本均适用&#xff09; 分辨率的调整 参考链接: Jmeter5.3字…...

Android 7 及以上夜神模拟器,Fiddler 抓 https 包

文章目录 问题描述解决方案环境准备操作步骤1、导出 Fiddler 证书并修改成 .pem 和 .0 文件2、修改夜神模拟器配置3、打开夜神模拟器设备的 USB 调试选项4、将0725b47c.0证书放入夜神模拟器系统证书目录5、夜神模拟器 cmd 环境配置6、给 0725b47c.0 证书赋予权限7、打开 fiddle…...

全国医院数据可视化分析系统

【大数据】全国医院数据可视化分析系统 &#xff08;完整系统源码开发笔记详细部署教程&#xff09;✅ 目录 一、项目简介二、项目界面展示三、项目视频展示 一、项目简介 &#x1f3e5; 项目名&#xff1a;医疗导航神器&#xff01;——《基于大数据的微医挂号网医院数据可视…...

音视频入门基础:RTCP专题(1)——RTCP官方文档下载

一、引言 实时传输控制协议&#xff08;Real-time Transport Control Protocol或RTP Control Protocol或简写RTCP&#xff09;是实时传输协议&#xff08;RTP&#xff09;的一个姐妹协议。RTCP由《RFC 3550》定义&#xff08;取代废弃的《RFC 1889》&#xff09;。RTP使用一个…...

蓝桥杯专项复习——结构体、输入输出

目录 结构体&#xff1a;排序 输入输出 结构体&#xff1a;排序 [NOIP2007]奖学金 #include<iostream> #include<cstring> #include<algorithm>using namespace std;const int N310; int n;struct Student {int chinese,math,eng,sum;int idx; }Stu[N];//定…...

工作记录 2017-01-06

工作记录 2017-01-06 序号 工作 相关人员 1 协助BPO进行Billing的工作。 修改CSV、EDI837的导入。 修改邮件上的问题。 更新RD服务器。 郝 修改的问题&#xff1a; 1、 In “Full Job Summary” (patient info.), sometime, the Visit->Facility is missed, then …...

探索 Rust 高效 Web 开发:Hyperlane 框架深度解析

探索 Rust 高效 Web 开发&#xff1a;Hyperlane 框架深度解析 在当今的 Web 开发领域&#xff0c;追求高性能、轻量级的框架一直是开发者们的不懈追求。对于 Rust 语言开发者而言&#xff0c;Hyperlane 框架正以其独特的魅力崭露头角&#xff0c;为构建现代 Web 服务提供了一种…...