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 款的应用完成原生鸿蒙开发,这么多的应用需要开发,也就意味着需要有更多的鸿蒙人才。鸿蒙开发工程师也将会迎来爆发式的增长,学习鸿蒙势在必行!

相关推荐
马可奥勒留5 小时前
《你以为职场是过家家?真正的高手都在用「职业化人际关系模型」》
程序员
袁煦丞6 小时前
数据库设计神器DrawDB:cpolar内网穿透实验室第595个成功挑战
前端·程序员·远程工作
codeGoogle6 小时前
不吹不黑理性讨论:疑似华为员工匿名指控盘古大模型造假,你怎么看?
程序员
coder_pig8 小时前
跟🤡杰哥一起学Flutter (三十四、玩转Flutter手势✋)
前端·flutter·harmonyos
陈随易8 小时前
MoonBit助力前端开发,加密&性能两不误,斐波那契测试提高3-4倍
前端·后端·程序员
simple丶8 小时前
【HarmonyOS】鸿蒙蓝牙连接与通信技术
harmonyos·arkts·arkui
前端世界10 小时前
HarmonyOS开发实战:鸿蒙分布式生态构建与多设备协同发布全流程详解
分布式·华为·harmonyos
难受啊马飞2.010 小时前
如何判断 AI 将优先自动化哪些任务?
运维·人工智能·ai·语言模型·程序员·大模型·大模型学习
Jalor11 小时前
Flutter + 鸿蒙 | Flutter 跳转鸿蒙原生界面
flutter·harmonyos
zhanshuo11 小时前
开发者必看!如何在HarmonyOS中快速调用摄像头功能
harmonyos