0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

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

jf_46214456 来源:jf_46214456 作者:jf_46214456 2024-05-11 16:16 次阅读

LinkedList底层通过双向链表实现,双向链表的每个节点都包含对前一个元素和后一个元素的引用。当需要查询元素时,可以从头遍历,也可以从尾部遍历,插入、删除效率高,查询效率低。LinkedList允许元素为null。

LinkedList和[List]相比,LinkedList是双向链表,可以快速地在头尾进行增删,而List是单向链表,无法双向操作。

LinkedList和[ArrayList]相比,插入数据效率LinkedList优于ArrayList,而查询效率ArrayList优于LinkedList。

推荐使用场景: 当需要频繁的插入删除时,推荐使用LinkedList高效操作。

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

  • T: Type,类

icon-note.gif说明:

本模块首批接口从API version 8开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。

导入模块

import LinkedList from '@ohos.util.LinkedList';

LinkedList

鸿蒙开发指导文档:[gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md]

属性

系统能力: SystemCapability.Utils.Lang

名称类型可读可写说明
lengthnumberLinkedList的元素个数。

constructor

constructor()

LinkedList的构造函数。

系统能力: SystemCapability.Utils.Lang

错误码:

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

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

示例:

let linkedList = new LinkedList();

add

add(element: T): boolean

在LinkedList尾部插入元素。

系统能力: SystemCapability.Utils.Lang

参数

参数名类型必填说明
elementT待插入的元素。

返回值:

类型说明
boolean插入成功返回true,否则返回false。

错误码:

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

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

示例:

let linkedList = new LinkedList();
let result = linkedList.add("a");
let result1 = linkedList.add(1);
let b = [1, 2, 3];
let result2 = linkedList.add(b);
let c = {name : "Dylon", age : "13"};
let result3 = linkedList.add(c);
let result4 = linkedList.add(false);

addFirst

addFirst(element: T): void

在LinkedList头部插入元素。

系统能力: SystemCapability.Utils.Lang

参数:

参数名类型必填说明
elementT待插入的元素。

错误码:

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

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

示例:

let linkedList = new LinkedList();
linkedList.addFirst("a");
linkedList.addFirst(1);
let b = [1, 2, 3];
linkedList.addFirst(b);
let c = {name : "Dylon", age : "13"};
linkedList.addFirst(c);
linkedList.addFirst(false);

insert

insert(index: number, element: T): void

在长度范围内任意插入指定元素。

系统能力: SystemCapability.Utils.Lang

参数:

参数名类型必填说明
indexnumber插入位置索引
elementT插入元素。

错误码:

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

错误码ID错误信息
10200011The insert method cannot be bound.
10200001The value of index is out of range.

示例:

let linkedList = new LinkedList();
linkedList.insert(0, "A");
linkedList.insert(1, 0);
linkedList.insert(2, true);

has

has(element: T): boolean

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

系统能力: SystemCapability.Utils.Lang

参数:

参数名类型必填说明
elementT指定元素。

返回值:

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

错误码:

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

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

示例:

let linkedList = new LinkedList();
linkedList.add("squirrel");
let result = linkedList.has("squirrel");

get

get(index: number): T

根据下标获取LinkedList中的元素。

系统能力: SystemCapability.Utils.Lang

参数:

参数名类型必填说明
indexnumber指定的下标值。

返回值:

类型说明
T根据下标查找到的元素,元素不存在返回undefined。

错误码:

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

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

示例:

let linkedList = new LinkedList();
linkedList.add(2);
linkedList.add(4);
linkedList.add(5);
linkedList.add(2);
linkedList.add(1);
linkedList.add(2);
linkedList.add(4);
let result = linkedList.get(2);

getLastIndexOf

getLastIndexOf(element: T): number

返回指定元素最后一次出现时的下标值,查找失败返回-1。

系统能力: SystemCapability.Utils.Lang

参数:

参数名类型必填说明
elementT指定元素。

返回值:

类型说明
number返回指定元素最后一次出现时的下标值,查找失败返回-1。

错误码:

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

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

示例:

let linkedList = new LinkedList();
linkedList.add(2);
linkedList.add(4);
linkedList.add(5);
linkedList.add(2);
linkedList.add(1);
linkedList.add(2);
linkedList.add(4);
let result = linkedList.getLastIndexOf(2);

getIndexOf

getIndexOf(element: T): number

返回指定元素第一次出现时的下标值,查找失败返回-1。

系统能力: SystemCapability.Utils.Lang

参数:

参数名类型必填说明
elementT指定元素。

返回值:

类型说明
number返回指定元素第一次出现时的下标值,查找失败返回-1。

错误码:

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

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

示例:

let linkedList = new LinkedList();
linkedList.add(2);
linkedList.add(4);
linkedList.add(5);
linkedList.add(2);
linkedList.add(1);
linkedList.add(2);
linkedList.add(4);
let result = linkedList.getIndexOf(2);

removeByIndex

removeByIndex(index: number): T

根据元素的下标值查找元素,并将其删除。

系统能力: SystemCapability.Utils.Lang

参数:

参数名类型必填说明
indexnumber指定元素的下标值。

返回值:

类型说明
T返回删除的元素,如果为空返回undefined。

错误码:

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

错误码ID错误信息
10200011The removeByIndex method cannot be bound.
10200001The value of index is out of range.

示例:

let linkedList = new LinkedList();
linkedList.add(2);
linkedList.add(4);
linkedList.add(5);
linkedList.add(2);
linkedList.add(4);
let result = linkedList.removeByIndex(2);

removeFirst

removeFirst(): T

删除并返回LinkedList的第一个元素。

系统能力: SystemCapability.Utils.Lang

返回值:

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

错误码:

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

错误码ID错误信息
10200011The removeFirst method cannot be bound.
10200010Container is empty.

示例:

let linkedList = new LinkedList();
linkedList.add(2);
linkedList.add(4);
linkedList.add(5);
linkedList.add(2);
linkedList.add(4);
let result = linkedList.removeFirst();

removeLast

removeLast(): T

删除并返回LinkedList的最后一个元素。

系统能力: SystemCapability.Utils.Lang

返回值:

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

错误码:

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

错误码ID错误信息
10200011The removeLast method cannot be bound.
10200010Container is empty.

示例:

let linkedList = new LinkedList();
linkedList.add(2);
linkedList.add(4);
linkedList.add(5);
linkedList.add(2);
linkedList.add(4);
let result = linkedList.removeLast();

remove

remove(element: T): boolean

删除查找到的第一个指定的元素。

系统能力: SystemCapability.Utils.Lang

参数:

参数名类型必填说明
elementT指定元素。

返回值:

类型说明
boolean删除成功返回true,否则返回false。

错误码:

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

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

示例:

let linkedList = new LinkedList();
linkedList.add(2);
linkedList.add(4);
linkedList.add(5);
linkedList.add(4);
let result = linkedList.remove(2);

removeFirstFound

removeFirstFound(element: T): boolean

删除第一次出现的指定元素。

系统能力: SystemCapability.Utils.Lang

参数:

参数名类型必填说明
elementT指定元素。

返回值:

类型说明
boolean删除成功返回true,删除失败或不存在该元素时返回false。

错误码:

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

错误码ID错误信息
10200011The removeFirstFound method cannot be bound.
10200010Container is empty.
10200017The element does not exist in this container.

示例:

let linkedList = new LinkedList();
linkedList.add(2);
linkedList.add(4);
linkedList.add(5);
linkedList.add(4);
let result = linkedList.removeFirstFound(4);

removeLastFound

removeLastFound(element: T): boolean

删除最后一次出现的指定元素。

系统能力: SystemCapability.Utils.Lang

参数:

参数名类型必填说明
elementT指定元素。

返回值:

类型说明
boolean删删除成功返回true,删除失败或不存在该元素时返回false。

错误码:

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

错误码ID错误信息
10200011The removeLastFound method cannot be bound.
10200010Container is empty.
10200017The element does not exist in this container.

示例:

let linkedList = new LinkedList();
linkedList.add(2);
linkedList.add(4);
linkedList.add(5);
linkedList.add(4);
let result = linkedList.removeLastFound(4);

clone

clone(): LinkedList

克隆一个与LinkedList相同的实例,并返回克隆后的实例。修改克隆后的实例并不会影响原实例。

系统能力: SystemCapability.Utils.Lang

返回值:

类型说明
LinkedList返回LinkedList对象实例。

错误码:

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

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

示例:

let linkedList = new LinkedList();
linkedList.add(2);
linkedList.add(4);
linkedList.add(5);
linkedList.add(4);
let result = linkedList.clone();

forEach

forEach(callbackFn: (value: T, index?: number, LinkedList?: LinkedList) => void, thisArg?: Object): void

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

系统能力: SystemCapability.Utils.Lang

参数:

参数名类型必填说明
callbackFnfunction回调函数。
thisArgObjectcallbackfn被调用时用作this值。

callbackfn的参数说明:

参数名类型必填说明
valueT当前遍历到的元素。
indexnumber当前遍历到的下标值。
LinkedListLinkedList当前调用forEach方法的实例对象。

错误码:

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

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

示例:

let linkedList = new LinkedList();
linkedList.add(2);
linkedList.add(4);
linkedList.add(5);
linkedList.add(4);
linkedList.forEach((value, index) = > {
    console.log("value:" + value, "index:" + index);
});

clear

clear(): void

清除LinkedList中的所有元素,并把length置为0。

系统能力: SystemCapability.Utils.Lang

错误码:

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

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

示例:

let linkedList = new LinkedList();
linkedList.add(2);
linkedList.add(4);
linkedList.add(5);
linkedList.add(4);
linkedList.clear();

set

set(index: number, element: T): T

将此LinkedList中指定位置的元素替换为指定元素。

系统能力: SystemCapability.Utils.Lang

参数:

参数名类型必填说明
indexnumber查找的下标值。
elementT用来替换的元素。

返回值:

类型说明
T返回替换后的元素,如果为空返回undefined。

错误码:

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

错误码ID错误信息
10200011The set method cannot be bound.
10200001The value of index is out of range.

示例:

let linkedList = new LinkedList();
linkedList.add(2);
linkedList.add(4);
linkedList.add(5);
linkedList.add(4);
let result = linkedList.set(2, "b");

convertToArray

convertToArray(): Array

把当前LinkedList实例转换成数组,并返回转换后的数组。

系统能力: SystemCapability.Utils.Lang

返回值:

类型说明
Array返回转换后的数组。

错误码:

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

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

示例:

let linkedList = new LinkedList();
linkedList.add(2);
linkedList.add(4);
linkedList.add(5);
linkedList.add(4);
let result = linkedList.convertToArray();

getFirst

getFirst(): T

获取LinkedList实例中的第一个元素。

系统能力: SystemCapability.Utils.Lang

返回值:

类型说明
T返回对应元素,如果元素为空返回undefined。

错误码:

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

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

示例:

let linkedList = new LinkedList();
linkedList.add(2);
linkedList.add(4);
linkedList.add(5);
linkedList.add(4);
let result = linkedList.getFirst();

getLast

getLast(): T

获取LinkedList实例中的最后一个元素。

系统能力: SystemCapability.Utils.Lang

返回值:

类型说明
T返回对应元素,如果为元素空返回undefined。

错误码:

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

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

示例:

let linkedList = new LinkedList();
linkedList.add(2);
linkedList.add(4);
linkedList.add(5);
linkedList.add(4);
let result = linkedList.getLast();

[Symbol.iterator]

HarmonyOSOpenHarmony鸿蒙文档籽料:mau123789是v直接拿

搜狗高速浏览器截图20240326151450.png

Symbol.iterator: IterableIterator

返回一个迭代器,迭代器的每一项都是一个 JavaScript 对象,并返回该对象。

系统能力: SystemCapability.Utils.Lang

返回值:

类型说明
IterableIterator返回一个迭代器。

错误码:

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

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

示例:

let linkedList = new LinkedList();
linkedList.add(2);
linkedList.add(4);
linkedList.add(5);
linkedList.add(4);

// 使用方法一:
for (let item of linkedList) { 
  console.log("value:" + item); 
} 

// 使用方法二:
let iter = linkedList[Symbol.iterator]();
let temp = iter.next().value;
while(temp != undefined) {
  console.log("value:" + temp);
  temp = iter.next().value;
}

审核编辑 黄宇

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 接口
    +关注

    关注

    33

    文章

    7785

    浏览量

    148854
  • 鸿蒙
    +关注

    关注

    55

    文章

    1829

    浏览量

    42172
  • OpenHarmony
    +关注

    关注

    24

    文章

    3424

    浏览量

    15227
收藏 人收藏

    评论

    相关推荐

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

    ArrayList是一种线性数据结构,底层基于数组实现。ArrayList会根据实际需要动态调整容量,每次扩容增加50%。
    的头像 发表于 04-25 18:48 445次阅读
    <b class='flag-5'>OpenHarmony</b><b class='flag-5'>语言</b>基础类库【@<b class='flag-5'>ohos.util</b>.ArrayList (<b class='flag-5'>线性</b><b class='flag-5'>容器</b>ArrayList)】

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

    HashMap底层使用数组+链表+红黑树的方式实现,查询、插入和删除的效率都很高。HashMap存储内容基于key-value的键值对映射,不能有重复的key,且一个key只能对应一个value。
    的头像 发表于 04-25 22:12 611次阅读
    <b class='flag-5'>OpenHarmony</b><b class='flag-5'>语言</b>基础类库【@<b class='flag-5'>ohos.util</b>.HashMap (非<b class='flag-5'>线性</b><b class='flag-5'>容器</b>HashMap)】

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

    List底层通过单向链表实现,每个节点有一个指向后一个元素的引用。当需要查询元素时,必须从头遍历,插入、删除效率高,查询效率低。List允许元素为null。
    的头像 发表于 05-10 16:57 467次阅读
    <b class='flag-5'>OpenHarmony</b><b class='flag-5'>语言</b>基础类库【@<b class='flag-5'>ohos.util</b>.List (<b class='flag-5'>线性</b><b class='flag-5'>容器</b>List)】

    List中的ArrayList和LinkedList有什么区别呢

    前言说真的,在 Java 使用最多的集合中,List 绝对占有一席之地的,它和 Map 一样适用于很多场景,非常方便我们的日常开发,毕竟存储一个列表的需求随处可见。尽管如此,还是有很多同学没有弄
    发表于 12-23 07:21

    HarmonyOS方舟开发框架容器API的介绍与使用

    通过数组实现,包括ArrayList、Vector、List、LinkedList、Deque、Queue、Stack七种。线性容器API,充分考虑了数据访问的速度,实现了运行时(R
    发表于 03-07 11:40

    OpenHarmony 3.1 Beta版本关键特性解析——ArkUI容器API介绍

    及使用场景。下面,我们将为大家一一道来。1.1线性容器线性容器底层主要通过数组实现,包括 A
    发表于 04-24 14:58

    HarmonyOS/OpenHarmony应用开发-Stage模型ArkTS语言扩展能力基

    \'@ohos.app.ability.ExtensionAbility\'; 接口示例: *附件:HarmonyOSOpenHarmony应用开发-stage模型ArkTS语言扩展能力基
    发表于 04-26 10:00

    HarmonyOS线性容器特性及使用场景

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

    HarmonyOS语言基础开发指南上线啦!

    指南中提供了详细的介绍和开发指导,帮助开发者全面了解并发实现、容器基础操作、XML的生成解析与转换等。 本期HarmonyOS开发者资料直通车带您快速了解内容干货~ 一、语言基础
    发表于 10-18 16:36

    OpenHarmony C++公共基础应用案例:Thread

    OpenHarmony C++公共基础应用案例:Thread 1、程序简介 该程序是基于OpenHarmony的C++公共基础
    发表于 11-22 11:50

    LinkedList的源码分析

     LinkedList也和ArrayList一样实现了List接口,但是它执行插入和删除操作时比ArrayList更加高效,因为它是基于链表的。基于链表也决定了它在随机访问方面要比ArrayList
    发表于 11-28 15:06 1795次阅读
    <b class='flag-5'>LinkedList</b>的源码分析

    OpenHarmony 3.1 Beta版本关键特性解析——ArkUI开发框架容器类API的介绍与使用

    线性容器类底层主要通过数组实现,包括 ArrayList、Vector、List、LinkedList、Deque、Queue、Stack 七种。线性
    的头像 发表于 03-17 10:48 723次阅读

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

    Deque(double ended queue)根据循环队列的数据结构实现,符合先进先出以及先进后出的特点,支持两端的元素插入和移除。Deque会根据实际需要动态调整容量,每次进行两倍扩容。
    的头像 发表于 04-25 21:17 105次阅读
    <b class='flag-5'>OpenHarmony</b><b class='flag-5'>语言</b>基础类库【@<b class='flag-5'>ohos.util</b>.Deque (<b class='flag-5'>线性</b><b class='flag-5'>容器</b>Deque)】

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

    HashSet基于[HashMap]实现。在HashSet中,只对value对象进行处理。
    的头像 发表于 04-26 15:13 169次阅读
    <b class='flag-5'>OpenHarmony</b><b class='flag-5'>语言</b>基础类库【@<b class='flag-5'>ohos.util</b>.HashSet (非<b class='flag-5'>线性</b><b class='flag-5'>容器</b>HashSet)】

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

    TreeMap可用于存储具有关联关系的key-value键值对集合,存储元素中key值唯一,每个key对应一个value。
    的头像 发表于 04-28 15:23 141次阅读
    <b class='flag-5'>OpenHarmony</b><b class='flag-5'>语言</b>基础类库【@<b class='flag-5'>ohos.util</b>.TreeMap (非<b class='flag-5'>线性</b><b class='flag-5'>容器</b>TreeMap)】