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

ArkTS---空安全、模块、并发

空安全

默认情况下,Arkts中的所有类型都是不可为空的,因此类型的值不能为空

以下情况编译会报错

如果避免上述情况可以使用联合类型

非空断言

后缀运算符使用 ! 可用于断言其操作不为空

如果运行时值非空则通过,如果值为空,则发生运行时的异常

空值合并运算符

空值合并二元运算符:?? 用于检查左侧表达式的求值是否等于null或者undefined如果是,则表达式的结果为右侧表达式:否则,结果为左侧表达式。

举个例子: a ?? b 等价与三元运算符(a !=null && a != undefined ? a:b)

可选链

在访问对象属性时,如果该属性是undefined或者null,可选链运算符会返回undefined

模块

导出
程序可划分为多组编译单元或模块,每个模块都有其自己的作用域。
在模块中创建的任何声明(变量、函数、类等)在该模块之外都不可见,除非它们被显示导出
导出使用关键字  export 导出顶层的声明
未导出的声明被视为私有名称,只能在声明该名称的模块

导入

导入声明用于导入从其他模块导出的实体,并在当前模块中提供其绑定

导入声明由两部分组成:

1.导入路径:用于指定导入的模块;

2.导入绑定:用于定义导入的模块中的可用实体集和使用形式

并发


 并发是指在同一时间内,存在多个任务同时执行。对于多核设备,这些任务可能同时在不同cpu上并行执行。对于单核设备,多个并发任务不会在同一时刻并发执行。

为了提升应用的响应速度与帧率,避免了耗时任务对主线程的影响,Arkts提供了异步并发和多线程并发两种处理策略。

异步并发是指异步代码在执行到一定程度后会被暂停,以便在未来某个时间点继续执行。

这种情况下,同一时间只有一段代码在执行。ArkTS通过Promise和async/await提供异步并发能力,适用于单次I/O任务的开发场景。  

(1)异步并发
Promise和async/await提供异步并发能力,是标准的JS异步语法。异步代码会被挂起并在之后继续执行,同一时间只有一段代码执行。

异步语法是一种编程语言的特性,允许程序在执行某些操作时不必等待其完成,而是可以继续执行其他操作。

(2)promise
Promise是一种用于处理异步操作的对象,可以将异步操作转换为类似于同步操作的风格,以方便代码编写和维护。

Promise提供了一个状态机制来管理异步操作的不同阶段,并提供了一些方法来注册回调函数以处理异步操作的成功或失败的结果。

最基本的用法是通过构造函数实例化一个Promise对象,同时传入一个带有两个参数的函数,通常称为executor函数。executor函数接收两个参数:resolve和reject,分别表示异步操作成功和失败时的回调函数。

Promise对象创建后,可以使用then方法和catch方法指定fulfilled状态和rejected状态的回调函数。then方法可接受两个参数,一个处理fulfilled状态的函数,另一个处理rejected状态的函数。只传一个参数则表示当Promise对象状态变为fulfilled时,then方法会自动调用这个回调函数,并将Promise对象的结果作为参数传递给它。使用catch方法注册一个回调函数,用于处理“失败”的结果,即捕获Promise的状态改变为rejected状态或操作失败抛出的异常

(3)async/await
async/await是一种用于处理异步操作的Promise语法,使得编写异步代码变得更加简单和易读。

通过使用async关键字声明一个函数为异步函数,并使用await关键字等待Promise的解析(完成或拒绝),以同步的方式编写异步操作的代码。

async函数是一个返回Promise对象的函数,用于表示一个异步操作。

在async函数内部,可以使用await关键字等待一个Promise对象的解析,并返回其解析值。

如果一个async函数抛出异常,那么该函数返回的Promise对象将被拒绝,并且异常信息会被传递给Promise对象的onRejected()方法


http://www.kler.cn/a/402737.html

相关文章:

  • springboot 使用笔记
  • C语言笔记(自定义类型:结构体、枚举、联合体 )
  • BERT的中文问答系统38
  • RabbitMQ实现异步下单与退单
  • 【LeetCode热题100】队列+宽搜
  • springboot购物推荐网站的设计与实现(代码+数据库+LW)
  • 【C++】踏上C++学习之旅(九):深入“类和对象“世界,掌握编程的黄金法则(四)(包含四大默认成员函数的练习以及const对象)
  • React 中使用 Axios 进行 HTTP 请求
  • 国内docker pull拉取镜像的解决方法
  • SpringBoot+Vue 2 多方法实现(图片/视频/报表)文件上传下载,示例超详细 !
  • Vue 3 组件通信:深入理解 Props 和 Emits 的使用与最佳实践
  • 【Spring MVC】初步了解Spring MVC的基本概念与如何与浏览器建立连接
  • 库的操作(MySQL)
  • 【设计模式】【创建型模式(Creational Patterns)】之抽象工厂模式(Abstract Factory Pattern)
  • 探索C/C++的奥秘之list
  • 实验室资源调度系统:基于Spring Boot的创新
  • 技术总结(三十三)
  • Flink使用详解
  • 【5】GD32H7xx CAN发送及FIFO接收
  • React 远程仓库拉取项目部署,无法部署问题
  • 【VTK】MFC中使用VTK9.3
  • 1+X应急响应(网络)威胁情报分析:
  • 百度遭初创企业指控抄袭,维权还是碰瓷?
  • Github 2024-11-20C开源项目日报 Top9
  • 【Python项目】基于Python的医疗知识图谱问答系统
  • 低代码开发平台搭建思考与实战