第二十课:HarmonyOS Next异步编程实战:Promise与async/await深度解析

一、异步编程核心概念

HarmonyOS Next基于ArkTS的‌单线程模型‌实现高效异步编程,通过Promise与async/await解决传统回调地狱问题,提升代码可维护性‌

其核心优势包括:

  1. ‌非阻塞执行‌:异步任务挂起后主线程继续响应UI操作‌
  2. ‌简化并发逻辑‌:链式调用替代多层嵌套回调‌
  3. ‌统一错误处理‌:通过catch或try/catch集中管理异常‌

二、Promise核心用法

1. 状态与基本语法

Promise包含三种状态:

‌Pending‌:异步操作进行中‌

‌Fulfilled‌:任务成功完成‌

‌Rejected‌:任务执行失败‌

代码示例:创建Promise对象

javascript 复制代码
const fetchData = new Promise<string>((resolve, reject) => {  
  setTimeout(() => {  
    const success = Math.random() > 0.5;  
    success ? resolve('数据加载成功') : reject('请求超时');  
  }, 1000);  
});  

fetchData  
  .then(result => console.log(result))  
  .catch(error => console.error(error));  

2. 链式调用与错误处理

通过.then()串联多个异步任务,避免回调嵌套:

css 复制代码
// 模拟用户登录流程  
login(userId: string)  
  .then(token => getUserInfo(token))  
  .then(info => saveLocalStorage(info))  
  .catch(error => showToast('流程失败:' + error));  

三、async/await进阶开发

1. 基础语法与执行流程

‌async标记函数‌:声明异步函数隐式返回Promise‌37

‌await暂停执行‌:等待Promise完成后再继续后续代码‌36

代码示例:网络请求封装

vbnet 复制代码
async function loadUserData() {  
  try {  
    const token = await fetchToken();  
    const data = await fetchUserInfo(token);  
    return processData(data);  
  } catch (error) {  
    console.error('加载失败:', error);  
    throw error;  
  }  
}  

2. 并发执行优化

使用Promise.all提升多个独立任务的执行效率:

javascript 复制代码
// 并行加载图片与配置  
async function initApp() {  
  const [images, config] = await Promise.all([  
    fetchImageList(),  
    loadAppConfig()  
  ]);  
  // 合并结果后渲染  
}  

四、异步数据加载实战

1. 网络请求场景

封装HTTP请求模块实现统一拦截:

javascript 复制代码
async function safeFetch(url: string) {  
  const response = await fetch(url);  
  if (!response.ok) throw new Error(`HTTP ${response.status}`);  
  return response.json();  
}  

// 使用示例  
async function loadNews() {  
  const news = await safeFetch('https://api.example.com/news');  
  updateUI(news);  
}  

2. 文件读写场景

结合@ohos.fileio实现异步文件操作:

javascript 复制代码
async function writeLog(message: string) {  
  const filePath = 'logs/app.log';  
  try {  
    await fileio.writeText(filePath, message + '\n', { append: true });  
  } catch (e) {  
    console.error('日志写入失败:', e);  
  }  
}  
相关推荐
autumn20056 小时前
Flutter 框架跨平台鸿蒙开发 - 虚拟纪念馆
flutter·华为·harmonyos
2301_822703206 小时前
渐变壁纸生成:基于鸿蒙Flutter的跨平台壁纸创建工具
flutter·华为·harmonyos·鸿蒙
人间打气筒(Ada)7 小时前
「码动四季·开源同行」HarmonyOS应用开发:常见组件
华为·开源·harmonyos·组件·布局·鸿蒙开发
三声三视7 小时前
ArkTS 自定义组件完全指南:@Builder、@Extend、@Styles 实战解析
华为·harmonyos
Utopia^9 小时前
Flutter 框架跨平台鸿蒙开发 - 旅行预算管家
flutter·华为·harmonyos
李李李勃谦10 小时前
Flutter 框架跨平台鸿蒙开发 - 星空识别助手
flutter·华为·harmonyos
李李李勃谦10 小时前
Flutter 框架跨平台鸿蒙开发 - 本地生活服务预约
flutter·华为·生活·harmonyos
我的世界洛天依10 小时前
胡桃讲编程:早期华为手机(比如畅享等)可以升级鸿蒙吗?
华为·harmonyos
2301_8227032010 小时前
开源鸿蒙跨平台Flutter开发:幼儿疫苗全生命周期追踪系统:基于 Flutter 的免疫接种档案与状态机设计
算法·flutter·华为·开源·harmonyos·鸿蒙
2301_8227032011 小时前
鸿蒙flutter三方库实战——教育与学习平台:Flutter Markdown
学习·算法·flutter·华为·harmonyos·鸿蒙