OpenHarmony语言基础类库【@ohos.util.Deque (线性容器Deque)】

Deque(double ended queue)根据循环队列的数据结构实现,符合先进先出以及先进后出的特点,支持两端的元素插入和移除。Deque会根据实际需要动态调整容量,每次进行两倍扩容。

Deque和[Queue]()相比,Queue的特点是先进先出,只能在头部删除元素,尾部增加元素。

与[Vector]()相比,它们都支持在两端增删元素,但Deque不能进行中间插入的操作。对头部元素的插入删除效率高于Vector,而Vector访问元素的效率高于Deque。

推荐使用场景: 需要频繁在集合两端进行增删元素的操作时,推荐使用Deque。

文档中存在泛型的使用,涉及以下泛型标记符:

导入模块

cpp 复制代码
import Deque from '@ohos.util.Deque'; 

Deque

属性

系统能力: SystemCapability.Utils.Lang

名称 类型 可读 可写 说明
length number Deque的元素个数。

constructor

constructor()

Deque的构造函数。

系统能力: SystemCapability.Utils.Lang

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200012 The Deque's constructor cannot be directly invoked.

示例:

cpp 复制代码
let deque = new Deque();

insertFront

insertFront(element: T): void

在deque头部插入元素。

系统能力: SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
element T 插入的元素。

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200011 The insertFront method cannot be bound.

示例:

cpp 复制代码
let deque = new Deque();
deque.insertFront("a");
deque.insertFront(1);
let b = [1, 2, 3];
deque.insertFront(b);
let c = {name : "Dylon", age : "13"};
deque.insertFront(c);
deque.insertFront(false);

insertEnd

insertEnd(element: T): void

在deque尾部插入元素。

系统能力: SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
element T 插入的元素。

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200011 The insertEnd method cannot be bound.

示例:

cpp 复制代码
let deque = new Deque();
deque.insertEnd("a");
deque.insertEnd(1);
let b = [1, 2, 3];
deque.insertEnd(b);
let c = {name : "Dylon", age : "13"};
deque.insertEnd(c);
deque.insertEnd(false);

has

has(element: T): boolean

判断此Deque中是否含有该指定元素。

系统能力: SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
element T 指定的元素。

返回值:

类型 说明
boolean 如果包含指定元素返回true,否则返回false。

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200011 The has method cannot be bound.

示例:

cpp 复制代码
let deque = new Deque();
deque.insertFront("squirrel");
let result = deque.has("squirrel");

popFirst

popFirst(): T

删除并返回双端队列的首元素。

系统能力: SystemCapability.Utils.Lang

返回值:

类型 说明
T 返回被删除的首元素。

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200011 The popFirst method cannot be bound.

示例:

cpp 复制代码
let deque = new Deque();
deque.insertFront(2);
deque.insertFront(4);
deque.insertEnd(5);
deque.insertFront(2);
deque.insertFront(4);
let result = deque.popFirst();

popLast

popLast(): T

删除并返回双端队列的尾元素。

系统能力: SystemCapability.Utils.Lang

返回值:

类型 说明
T 返回被删除的尾元素。

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200011 The popLast method cannot be bound.

示例:

cpp 复制代码
let deque = new Deque();
deque.insertFront(2);
deque.insertEnd(4);
deque.insertFront(5);
deque.insertFront(2);
deque.insertFront(4);
let result = deque.popLast();

forEach

cpp 复制代码
forEach(callbackFn: (value: T, index?: number, deque?: Deque<T>) => void, thisArg?: Object): void

通过回调函数来遍历Deque实例对象上的元素以及元素对应的下标。

系统能力: SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
callbackFn function 回调函数。
thisArg Object callbackfn被调用时用作this值。

callbackfn的参数说明:

参数名 类型 必填 说明
value T 当前遍历到的元素。
index number 当前遍历到的下标值。
deque Deque<T> 当前调用forEach方法的实例对象。

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200011 The forEach method cannot be bound.

示例:

cpp 复制代码
let deque = new Deque();
deque.insertFront(2);
deque.insertEnd(4);
deque.insertFront(5);
deque.insertEnd(4);
deque.forEach((value, index) => {
    console.log("value:" + value, "index:" + index);
});

getFirst

getFirst(): T

获取Deque实例中的头元素。

系统能力: SystemCapability.Utils.Lang

返回值:

类型 说明
T 返回T类型的头元素

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200011 The getFirst method cannot be bound.

示例:

cpp 复制代码
let deque = new Deque();
deque.insertEnd(2);
deque.insertEnd(4);
deque.insertFront(5);
deque.insertFront(4);
let result = deque.getFirst();

getLast

getLast(): T

获取Deque实例中的尾元素。

系统能力: SystemCapability.Utils.Lang

返回值:

类型 说明
T 返回T类型的尾元素

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200011 The getLast method cannot be bound.

示例:

cpp 复制代码
let deque = new Deque();
deque.insertFront(2);
deque.insertFront(4);
deque.insertFront(5);
deque.insertFront(4);
let result = deque.getLast();

[Symbol.iterator]

Symbol.iterator\](): IterableIterator\ 返回一个迭代器,迭代器的每一项都是一个 JavaScript 对象,并返回该对象。 **系统能力:** SystemCapability.Utils.Lang **返回值:** | 类型 | 说明 | |-----------------------|----------| | IterableIterator\ | 返回一个迭代器。 | **错误码:** 以下错误码的详细介绍请参见[语言基础类库错误码](https://gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md "语言基础类库错误码")。 | 错误码ID | 错误信息 | |----------|---------------------------------------------| | 10200011 | The Symbol.iterator method cannot be bound. | **示例:** ```cpp let deque = new Deque(); deque.insertFront(2); deque.insertFront(4); deque.insertFront(5); deque.insertFront(4); // 使用方法一: for (let item of deque) { console.log("value:" + item); } // 使用方法二: let iter = deque[Symbol.iterator](); let temp = iter.next().value; while(temp != undefined) { console.log("value:" + temp); temp = iter.next().value; } ``` ## 鸿蒙开发岗位需要掌握那些核心要领? **目前还有很多小伙伴不知道要学习哪些鸿蒙技术?不知道重点掌握哪些?为了避免学习时频繁踩坑,最终浪费大量时间的。** 自己学习时必须要有一份实用的鸿蒙(Harmony NEXT)资料非常有必要。 这里我推荐,根据鸿蒙开发官网梳理与华为内部人员的分享总结出的开发文档。内容包含了:【**ArkTS、ArkUI、Stage模型、多端部署、分布式应用开发、音频、视频、WebGL、OpenHarmony多媒体技术、Napi组件、OpenHarmony内核、Harmony南向开发、鸿蒙项目实战**】等技术知识点。 废话就不多说了,接下来好好看下这份资料。 **如果你是一名Android、Java、前端等等开发人员,想要转入鸿蒙方向发展。可以直接领取这份资料辅助你的学习**。[鸿蒙OpenHarmony知识](https://juejin.cn/editor/drafts/%5B%60gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md%60%5D%28https://gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md%29 "鸿蒙OpenHarmony知识")←前往。下面是鸿蒙开发的学习路线图。 ![](https://file.jishuzhan.net/article/1784811919417282561/a3d5355e67fbacf574f5df80aa5fb6d8.webp) ![](https://file.jishuzhan.net/article/1784811919417282561/c2a1fb9c797d15530bb173ebf011660a.webp) ![](https://file.jishuzhan.net/article/1784811919417282561/b13062bb58b02f2b29eeffb4a584ccce.webp) 针对鸿蒙成长路线打造的鸿蒙学习文档。**鸿蒙(OpenHarmony )学习手册(共计1236页)与鸿蒙(OpenHarmony )开发入门教学视频**,帮助大家在技术的道路上更进一步。 #### 其中内容包含: 《鸿蒙开发基础》[鸿蒙OpenHarmony知识](https://link.zhihu.com/?target=https%3A//gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md "鸿蒙OpenHarmony知识")←前往 1. ArkTS语言 2. 安装DevEco Studio 3. 运用你的第一个ArkTS应用 4. ArkUI声明式UI开发 5. ....... 《鸿蒙开发进阶》[鸿蒙OpenHarmony知识](https://link.zhihu.com/?target=https%3A//gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md "鸿蒙OpenHarmony知识")←前往 1. Stage模型入门 2. 网络管理 3. 数据管理 4. 电话服务 5. 分布式应用开发 6. 通知与窗口管理 7. 多媒体技术 8. 安全技能 9. 任务管理 10. WebGL 11. 国际化开发 12. 应用测试 13. DFX面向未来设计 14. 鸿蒙系统移植和裁剪定制 15. ...... 《鸿蒙开发实战》[鸿蒙OpenHarmony知识](https://link.zhihu.com/?target=https%3A//gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md "鸿蒙OpenHarmony知识")←前往 1. ArkTS实践 2. UIAbility应用 3. 网络案例 4. ...... #### 最后 鸿蒙是完全具备无与伦比的机遇和潜力的;预计到年底将有 5,000 款的应用完成原生鸿蒙开发,这么多的应用需要开发,也就意味着需要有更多的鸿蒙人才。鸿蒙开发工程师也将会迎来爆发式的增长,学习鸿蒙势在必行!

相关推荐
幽蓝计划27 分钟前
Uniapp开发鸿蒙应用时如何运行和调试项目
华为·uni-app·harmonyos
魔术师ID8 小时前
HarmonyOS开发组件基础
华为·harmonyos
周胡杰11 小时前
组件导航 (Navigation)+flutter项目搭建-混合开发+分栏
数码相机·flutter·华为·电脑·harmonyos·鸿蒙
小陈从不熬夜15 小时前
HarmonyOS AVPlayer 音频播放器
华为·音视频·鸿蒙
特立独行的猫a17 小时前
HarmonyOS 影视应用APP开发--配套的后台服务go-imovie项目介绍及使用
华为·golang·harmonyos·影视app
梁下轻语的秋缘19 小时前
HarmonyOS:重构万物互联时代的操作系统范式
华为·重构·harmonyos
lpfasd12319 小时前
Flutter与Kotlin Multiplatform(KMP)深度对比及鸿蒙生态适配解析
flutter·kotlin·harmonyos
交叉编译之王 hahaha19 小时前
OpenHarmony 5.1.0 Release目录结构详细解析(3级目录)
arm开发·华为·harmonyos
交叉编译之王 hahaha20 小时前
RK3568-鸿蒙5.1与原生固件-扇区对比分析
华为·harmonyos
HarmonyOS_SDK20 小时前
【FAQ】HarmonyOS SDK 闭源开放能力 —Vision Kit (3)
harmonyos