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

相关推荐
王佳斌2 小时前
tp报错解决
harmonyos
coooliang2 小时前
【鸿蒙 NEXT】V1迁移V2状态管理
java·前端·harmonyos
江拥羡橙4 小时前
【目录-单选】鸿蒙HarmonyOS开发者基础
前端·ui·华为·typescript·harmonyos
爱笑的眼睛114 小时前
HarmonyOS应用开发:深入ArkUI声明式开发范式与最佳实践
华为·harmonyos
云水木石5 小时前
开源鸿蒙+龙芯CPU,能擦出怎样的火花?
华为·开源·harmonyos
特立独行的猫a6 小时前
开源OpenHarmony润开鸿HH-SCDAYU800A开发板开箱体验
开源·harmonyos·openharmony·hh-scdayu800a
redreamSo6 小时前
长大后为什么时间越来越快?我们活的是记忆并非时间,人生是由故事组成的
程序员
祥睿夫子8 小时前
鸿蒙 ArkTS 函数全解析:从基础定义到高级应用,新手也能轻松掌握
harmonyos
唐叔在学习8 小时前
盘点IDEA中那些实用的GIT小技巧
程序员·intellij idea
江拥羡橙10 小时前
【目录-多选】鸿蒙HarmonyOS开发者基础
前端·ui·华为·typescript·harmonyos