鸿蒙ArkTS基础类库——线性容器

容器类库概述

  • 容器类库,用于存储各种数据类型的元素,并具备一系列处理数据元素的方法,作为纯数据结构容器来使用具有一定的优势。
  • 容器类采用了类似静态语言的方式来实现,并通过对存储位置以及属性的限制,让每种类型的数据都能在完成自身功能的基础上去除冗余逻辑,保证了数据的高效访问,提升了应用的性能。
  • 当前提供了线性和非线性两类容器,共14种。每种容器都有自身的特性及使用场景,详情请参见线性容器和非线性容器。

线性容器

线性容器实现能按顺序访问的数据结构,其底层主要通过数组实现,包括ArrayList、Vector、List、LinkedList、Deque、Queue、Stack七种。

线性容器,充分考虑了数据访问的速度,运行时(Runtime)通过一条字节码指令就可以完成增、删、改、查等操作。

ArrayList

ArrayList即动态数组,可用来构造全局的数组对象。 当需要频繁读取集合中的元素时,推荐使用ArrayList。 ArrayList依据泛型定义,要求存储位置是一片连续的内存空间,初始容量大小为10,并支持动态扩容,每次扩容大小为原始容量的1.5倍。 ArrayList进行增、删、改、查操作的常用API如下:

操作描述
增加元素通过add(element: T)函数每次在数组尾部增加一个元素。
通过insert(element: T, index: number)在指定位置插入一个元素。
访问元素通过arr[index]获取指定index对应的value值,通过指令获取保证访问速度。
通过forEach(callbackFn: (value: T, index?: number, arrlist?: ArrayList) => void, thisArg?: Object): void访问整个ArrayList容器的元素。
通过Symbol.iterator:IterableIterator迭代器进行数据访问。
修改元素通过arr[index] = xxx修改指定index位置对应的value值。
删除元素通过remove(element: T)删除第一个匹配到的元素。
通过removeByRange(fromIndex: number, toIndex:number)删除指定范围内的元素。

Vector

Vector是指连续存储结构,可用来构造全局的数组对象。Vector依据泛型定义,要求存储位置是一片连续的内存空间,初始容量大小为10,并支持动态扩容,每次扩容大小为原始容量的2倍。 Vector和ArrayList相似,都是基于数组实现,但Vector提供了更多操作数组的接口。Vector在支持操作符访问的基础上,还增加了get/set接口,提供更为完善的校验及容错机制,满足用户不同场景下的需求。 API version 9开始,该接口不再维护,推荐使用ArrayList。 Vector进行增、删、改、查操作的常用API如下:

操作描述
增加元素通过add(element: T)函数每次在数组尾部增加一个元素。
通过insert(element: T, index: number)在指定位置插入一个元素。
访问元素通过vec[index]获取指定index对应的value值,通过指令获取保证访问速度。
通过get(index: number)获取指定index位置对应的元素。
通过getLastElement()获取最后一个元素。
通过getIndexOf(element:T)获取第一个匹配到元素的位置。
通过getLastIndexOf(element:T)获取最后一个匹配到元素的位置。
通过forEach(callbackFn: (value: T, index?: number, Vector?: Vector) => void, thisArg?: Object)访问整个Vector的元素。
通过Symbol.iterator:IterableIterator迭代器进行数据访问。
修改元素通过vec[index]=xxx修改指定index位置对应的value值。
通过set(index:number,element:T)修改指定index位置的元素值为element。
通过setLength(newSize:number)设置Vector的长度大小。
删除元素通过removeByIndex(index:number)删除index位置对应的value值。
通过remove(element:T)删除第一个匹配到的元素。
通过removeByRange(fromIndex:number,toIndex:number)删除指定范围内的元素。

List

List可用来构造一个单向链表对象,即只能通过头结点开始访问到尾节点。List依据泛型定义,在内存中的存储位置可以是不连续的。 List和LinkedList相比,LinkedList是双向链表,可以快速地在头尾进行增删,而List是单向链表,无法双向操作。 当需要频繁的插入删除时,推荐使用List高效操作。 可以通过get/set等接口对存储的元素进行修改,List进行增、删、改、查操作的常用API如下:

操作描述
增加元素通过add(element: T)函数每次在数组尾部增加一个元素。
通过insert(element: T, index: number)在指定位置插入一个元素。
访问元素通过list[index]获取指定index对应的value值,通过指令获取保证访问速度。
通过get(index: number)获取指定index位置对应的元素。
通过getFirst()获取第一个元素。
通过getLast()获取最后一个元素。
通过getIndexOf(element: T)获取第一个匹配到元素的位置。
通过getLastIndexOf(element: T)获取最后一个匹配到元素的位置。
通过forEach(callbackfn: (value:T, index?: number, list?: List)=> void,thisArg?: Object)访问整个List的元素。
通过Symbol.iterator:IterableIterator迭代器进行数据访问。
修改元素通过list[index] = xxx修改指定index位置对应的value值。
通过set(index:number, element: T)修改指定index位置的元素值为element。
通过replaceAllElements(callbackFn:(value: T,index?: number,list?: List)=>T,thisArg?: Object)对List内元素进行替换操作。
删除元素通过removeByIndex(index:number)删除index位置对应的value值。
通过remove(element:T)删除第一个匹配到的元素。

LinkedList

LinkedList可用来构造一个双向链表对象,可以在某一节点向前或者向后遍历List。LinkedList依据泛型定义,在内存中的存储位置可以是不连续的。 LinkedList和List相比,LinkedList是双向链表,可以快速地在头尾进行增删,而List是单向链表,无法双向操作。 LinkedList和ArrayList相比,插入数据效率LinkedList优于ArrayList,而查询效率ArrayList优于LinkedList。 当需要频繁的插入删除时,推荐使用LinkedList高效操作。 可以通过get/set等接口对存储的元素进行修改,LinkedList进行增、删、改、查操作的常用API如下:

操作描述
增加元素通过add(element: T)函数每次在数组尾部增加一个元素。
通过insert(index: number, element: T)在指定位置插入一个元素。
访问元素通过list[index]获取指定index对应的value值,通过指令获取保证访问速度。
通过get(index: number)获取指定index位置对应的元素。
通过getFirst()获取第一个元素。
通过getLast()获取最后一个元素。
通过getIndexOf(element: T)获取第一个匹配到元素的位置。
通过getLastIndexOf(element: T)获取最后一个匹配到元素的位置。
通过forEach(callbackFn: (value: T, index?: number, list?: LinkedList) => void, thisArg?: Object)访问整个LinkedList的元素。
通过Symbol.iterator:IterableIterator迭代器进行数据访问。
修改元素通过list[index]=xxx修改指定index位置对应的value值。
通过set(index: number,element: T)修改指定index位置的元素值为element。
删除元素通过removeByIndex(index: number)删除index位置对应的value值。
通过remove(element: T)删除第一个匹配到的元素。

Deque

Deque可用来构造双端队列对象,存储元素遵循先进先出以及先进后出的规则,双端队列可以分别从队头或者队尾进行访问。 Deque依据泛型定义,要求存储位置是一片连续的内存空间,其初始容量大小为8,并支持动态扩容,每次扩容大小为原始容量的2倍。Deque底层采用循环队列实现,入队及出队操作效率都比较高。 Deque和Queue相比,Queue的特点是先进先出,只能在头部删除元素,尾部增加元素。 Deque和Vector相比,它们都支持在两端增删元素,但Deque不能进行中间插入的操作。对头部元素的插入删除效率高于Vector,而Vector访问元素的效率高于Deque。 需要频繁在集合两端进行增删元素的操作时,推荐使用Deque。 Deque进行增、删、改、查操作的常用API如下:

操作描述
增加元素通过insertFront(element: T)函数每次在队头增加一个元素。
增加元素通过insertEnd(element: T)函数每次在队尾增加一个元素。
访问元素通过getFirst()获取队首元素的value值,但是不进行出队操作。
通过getLast()获取队尾元素的value值,但是不进行出队操作。
通过popFirst()获取队首元素的value值,并进行出队操作。
通过popLast()获取队尾元素的value值,并进行出队操作。
通过forEach(callbackFn:(value: T, index?: number, deque?: Deque) => void, thisArg?: Object)访问整个Deque的元素。
通过Symbol.iterator:IterableIterator迭代器进行数据访问。
修改元素通过forEach(callbackFn:(value: T, index?: number, deque?: Deque)=> void, thisArg?: Object)对队列进行修改操作。
删除元素通过popFirst()对队首元素进行出队操作并删除。
通过popLast()对队尾元素进行出队操作并删除。

Queue

Queue可用来构造队列对象,存储元素遵循先进先出的规则。 Queue依据泛型定义,要求存储位置是一片连续的内存空间,初始容量大小为8,并支持动态扩容,每次扩容大小为原始容量的2倍。 Queue底层采用循环队列实现,入队及出队操作效率都比较高。 Queue和Deque相比,Queue只能在一端删除一端增加,Deque可以两端增删。 一般符合先进先出的场景可以使用Queue。 Queue进行增、删、改、查操作的常用API如下:

操作描述
增加元素通过add(element: T)函数每次在队尾增加一个元素。
访问元素通过getFirst()获取队首元素的value值,但是不进行出队操作。
通过pop()获取队首元素的value值,并进行出队操作。
通过forEach(callbackFn: (value: T, index?: number, queue?: Queue) => void,thisArg?: Object)访问整个Queue的元素。
通过Symbol.iterator:IterableIterator迭代器进行数据访问。
修改元素通过forEach(callbackFn:(value: T, index?: number, queue?: Queue) => void,thisArg?: Object)对队列进行修改操作。
删除元素通过pop()对队首进行出队操作并删除。

Stack

Stack可用来构造栈对象,存储元素遵循先进后出的规则。 Stack依据泛型定义,要求存储位置是一片连续的内存空间,初始容量大小为8,并支持动态扩容,每次扩容大小为原始容量的1.5倍。Stack底层基于数组实现,入栈出栈均从数组的一端操作。 Stack和Queue相比,Queue基于循环队列实现,只能在一端删除,另一端插入,而Stack都在一端操作。 一般符合先进后出的场景可以使用Stack。 Stack进行增、删、改、查操作的常用API如下:

操作描述
增加元素通过push(item: T)函数每次在栈顶增加一个元素。
访问元素通过peek()获取栈顶元素的value值,但是不进行出栈操作。
通过pop()获取栈顶的value值,并进行出栈操作。
通过forEach(callbackFn: (value: T, index?: number, stack?: Stack) => void, thisArg?: Object)访问整个Stack的元素。
通过Symbol.iterator:IterableIterator迭代器进行数据访问。
通过locate(element: T)获取元素对应的位置。
修改元素通过forEach(callbackFn:(value: T, index?: number, stack?: Stack) => void, thisArg?: Object)对栈内元素进行修改操作。
删除元素通过pop()对栈顶进行出栈操作并删除。

线性容器的使用

此处列举常用的线性容器ArrayList、Vector、Deque、Stack、List的使用示例,包括导入模块、增加元素、访问元素及修改等操作。示例代码如下所示:

// ArrayList
import ArrayList from '@ohos.util.ArrayList'; // 导入ArrayList模块
 
let arrayList = new ArrayList();
arrayList.add('a');
arrayList.add(1); // 增加元素
console.info(`result: ${arrayList[0]}`); // 访问元素
arrayList[0] = 'one'; // 修改元素
console.info(`result: ${arrayList[0]}`);
 
// Vector
import Vector from '@ohos.util.Vector'; // 导入Vector模块
 
let vector = new Vector();
vector.add('a');
let b1 = [1, 2, 3];
vector.add(b1);
vector.add(false); // 增加元素
console.info(`result: ${vector[0]}`); // 访问元素
console.info(`result: ${vector.getFirstElement()}`); // 访问元素
 
// Deque
import Deque from '@ohos.util.Deque'; // 导入Deque模块
 
let deque = new Deque;
deque.insertFront('a');
deque.insertFront(1); // 增加元素
console.info(`result: ${deque[0]}`); // 访问元素
deque[0] = 'one'; // 修改元素
console.info(`result: ${deque[0]}`);
 
// Stack
import Stack from '@ohos.util.Stack'; // 导入Stack模块 
 
let stack = new Stack();
stack.push('a');
stack.push(1); // 增加元素
console.info(`result: ${stack[0]}`); // 访问元素
stack.pop(); // 删除栈顶元素并返回该删除元素
console.info(`result: ${stack.length}`);
 
// List
import List from '@ohos.util.List'; // 导入List模块
 
let list = new List;
list.add('a');
list.add(1);
let b2 = [1, 2, 3];
list.add(b2); // 增加元素
console.info(`result: ${list[0]}`); // 访问元素
console.info(`result: ${list.get(0)}`); // 访问元素

本文介绍了鸿蒙开发语言中ArkTS的容器类库,线性容器解析。更多有关鸿蒙进阶的技术,可以前往主页查看学习其他内容或者私信主页交流。下面是一张学习路线略缩图,完整在主页找我拿。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

自己动手写数据库: select 查询语句对应查询树的构造和执行

首先我们需要给原来代码打个补丁,在SelectScan 结构体初始化时需要传入 UpdateScan 接口对象,但很多时候我们需要传入的是 Scan 对象,因此我们需要做一个转换,也就是当初始化 SelectScan 时,如果传入的是 Scan 对象&am…

vs2019 配置liblas

vs2019 配置liblas liblas是一个开源的C库,用于读写LAS格式的点云数据。libLAS易于使用,广泛应用于各种点云处理任务。它支持基本的点云数据操作,如读取、写入和编辑LAS文件中的点。 1.源码下载 https://github.com/libLAS/libLAS 2.编译 首…

Docker多平台安装与配置指南

Docker的流行使得它成为开发者和运维人员不可或缺的工具。在本文中,将深入探讨如何在不同平台上安装和配置Docker,旨在为大家提供详尽的指南,确保他们能够顺利地使用这一强大的容器化工具。 Docker基础概念回顾 Docker利用容器技术&#xf…

设计模式-访问者模式

访问者模式是设计模式中行为型模式的一种(其他的还有如创建型、结构型),听说是设计模式中比较难理解的一种,最近项目中用到了该模式,所以今天总结和实践一下。 一、访问者模式要解决的问题: 稳定的数据结…

【系统架构】集群、分布式概念及系统架构演进过程

集群、分布式概念: 对食物没有太高要求的人在肚子饿的时候一般都会选择去兰州拉面、沙县小吃等小饭馆,这类小饭馆有个很显著的特点:洗菜、切菜、炒菜都是同一个人完成,如果厨子不舒服可能饭馆还会歇业。而一些人流量较大的饭馆的分…

MATLAB 平面拟合并可视化(34)

MATLAB 平面拟合并可视化(34) 一、效果二、代码一、效果 二、代码 % 生成三维点数据 x = rand(100, 1); y = rand(100, 1

nest框架的token登录,以及token校验

1.搭建项目 项目初始化: npm i -g nestjs/cli nest new project-name 在终端下执行这四个命令,生成两个新模块: nest g module auth nest g service auth nest g module users nest g service users 然后把这三个文件删掉,是没有…

【LeetCode刷题笔记(4)】【Python】【移动零】【简单】

文章目录 题目描述示例 1示例 2提示 解决方案题意拆解双指针算法双指针法的主要优点双指针法的使用场景举例: 解决方案:【双指针一次遍历】解题心得方案代码运行结果复杂度分析 结束语 移动零 题目描述 给定一个数组 nums,编写一个函数将所…

OWASP ESAPI 预防XSS跨站脚本攻击

跨站脚本攻击XSS案例&#xff1a;跨站脚本攻击XSS案例及其解决方案_xss攻击案例-CSDN博客 Java集成&#xff1a; 1、引入maven <!--OWASP ESAPI&#xff0c;防御 XSS跨站攻击--><dependency><groupId>org.owasp.esapi</groupId><artifactId>esa…

ArrayList集合的两个实例应用,有趣的洗牌算法与杨辉三角

本节课的内容&#xff0c;就让我们来学习一下ArrayList集合的应用&#xff0c;ArrayList的本质就是一个顺序表&#xff0c;那下面一起来学习吧 目录 一、杨辉三角 1.题目详情及链接 2.剖析题目 3.思路及代码 二、洗牌算法 1.创造牌对象 2.创造一副牌 3.洗牌操作 4.发…

Alibaba分布式事务组件Seata AT实战

1. 分布式事务简介 1.1 本地事务 大多数场景下&#xff0c;我们的应用都只需要操作单一的数据库&#xff0c;这种情况下的事务称之为本地事务(Local Transaction)。本地事务的ACID特性是数据库直接提供支持。本地事务应用架构如下所示&#xff1a; 在JDBC编程中&#xff0c;我…

力扣24 两两交换链表中的节点 Java版本

文章目录 题目解题方法Code 题目 给你一个链表&#xff0c;两两交换其中相邻的节点&#xff0c;并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题&#xff08;即&#xff0c;只能进行节点交换&#xff09;。 示例 1&#xff1a; 输入&#xff1a;hea…

事务隔离级别:保障数据库并发事务的一致性与性能

目录 引言 1. 事务隔离级别概述 2. 读未提交隔离级别 3. 读已提交隔离级别 4. 可重复读隔离级别 5. 串行化隔离级别 6. 保障事务隔离级别的机制 7. 如何选择合适的隔离级别 8. 结语 引言 在数据库管理系统&#xff08;DBMS&#xff09;中&#xff0c;事务隔离级别是一…

12.14_黑马数据结构与算法笔记Java

目录 120 二叉搜索树 min max 121 二叉搜索树 put 122 二叉搜索树 前任后任1 123 二叉搜索树 前任后任2 124 二叉搜索树 删除1 125 二叉搜索树 删除2 126 二叉搜索树 删除3 127 二叉搜索树 删除 递归1 128 二叉搜索树 删除 递归2 129 二叉搜索树 范围查询 130 二叉搜…

ADC学习总结

ADC的架构分类&#xff1a; 1、Delta-Sigma 采样率一般是在1M以内&#xff0c;位数一般可以做的很高&#xff0c;比如24位&#xff0c;Delta-Sigma ADC采用了过采样技术&#xff0c;不需要在模拟输入端加抗混叠滤波&#xff0c;由后端数字滤波器进行处理&#xff0c;通过信噪…

网工内推 | IT经理,50k*14薪,NP以上即可,七险一金

01 海天瑞声 招聘岗位&#xff1a;IT经理 职责描述&#xff1a; 1、IT基础架构的方案制定、实施和日常维护&#xff0c;包括机房建设运维、服务器配置及运维、网络规划及运维、上网行为管理、电话、电话、监控、门禁等各类弱电系统搭建及运维 2、负责公司环境及网络安全防御体…

WEB服务器介绍

Web服务器是指驻留于因特网上某种类型计算机的程序。当Web浏览器连到服务器上并请求文件时&#xff0c;服务器将处理该请求并将文件发送到该浏览器上&#xff0c;附带的信息会告诉浏览器如何查看该文件&#xff0c;即文WEB服务器件类型。服务器使用HTTP进行信息交流&#xff0c…

ASF-YOLO开源 | SSFF融合+TPE编码+CPAM注意力,精度提升!

目录 摘要 1 Introduction 2 Related work 2.1 Cell instance segmentation 2.2 Improved YOLO for instance segmentation 3 The proposed ASF-YOLO model 3.1 Overall architecture 3.2 Scale sequence feature fusion module 3.3 Triple feature encoding module …

Kvaser Leaf v3 重磅上新!报文速率高达20000条/秒!支持CAN FD!EAN: 73-30130-01424-4

作为CAN总线领域的专家&#xff0c;Kvaser深耕行业40年&#xff0c;至今已经累计推出100多款CAN产品。其中稳定小巧、便携易用的Kvaser经典Leaf系列是将计算机与CAN网络连接并获取CAN/CAN FD数据的最简单、性价比最高的方法之一。Kvaser秉持着将用户放在重要位置的原则&#xf…

6.5.编解码器信息的收集

那在上节课中呢&#xff1f;我向你介绍了add track相关的内容&#xff0c;那今天呢&#xff1f;我们来看看编解码器信息的收集。那在这里呢&#xff0c;我们需要问几个重要的问题&#xff0c;那首先呢&#xff0c;就是我们上节课通过&#xff0c;可以让web rtc知道我们都要传输…