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

TreeSet基于[TreeMap]实现,在TreeSet中,只对value对象进行处理。TreeSet可用于存储一系列值的集合,元素中value唯一且有序。

TreeSet和[HashSet]相比,HashSet中的数据无序存放,而TreeSet是有序存放。它们集合中的元素都不允许重复,但HashSet允许放入null值,TreeSet不建议存放null值,可能会对排序结果产生影响。

推荐使用场景: 一般需要存储有序集合的场景,可以使用TreeSet。

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

  • T:Type,类

说明:

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

导入模块

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

TreeSet

鸿蒙开发指导文档:gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md点击或者复制转到。

属性

系统能力: SystemCapability.Utils.Lang

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

constructor

constructor(comparator?: (firstValue: T, secondValue: T) => boolean)

TreeSet的构造函数,支持通过比较函数对元素进行升序或降序排序。

系统能力: SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
comparator function 用户自定义的比较函数,可通过比较关系对元素进行排序。默认值为hole(一个空白占位符),表示不提供比较函数。

错误码:

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

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

示例:

cpp 复制代码
let treeSet = new TreeSet();
//使用comparator firstValue < secondValue,表示期望结果为升序排序。反之firstValue > secondValue,表示为降序排序。
let treeSet : TreeSet<string> = new TreeSet<string>((firstValue: string, secondValue: string) : boolean => {return firstValue < secondValue});
treeSet.add("a");
treeSet.add("c");
treeSet.add("d");
treeSet.add("b");
let numbers = Array.from(treeSet.values())
for (let item of numbers) {
  console.log("TreeSet:" + item);
}

isEmpty

isEmpty(): boolean

判断该容器是否为空。

系统能力: SystemCapability.Utils.Lang

返回值:

类型 说明
boolean 为空返回true,不为空返回false。

错误码:

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

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

示例:

cpp 复制代码
const treeSet = new TreeSet();
let result = treeSet.isEmpty();

has

has(value: T): boolean

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

系统能力: SystemCapability.Utils.Lang

参数:

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

返回值:

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

错误码:

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

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

示例:

cpp 复制代码
let treeSet = new TreeSet();
treeSet.add(123);
let result = treeSet.has(123);

getFirstValue

getFirstValue(): T

获取容器中排序第一的数据,为空时返回undefined。

系统能力: SystemCapability.Utils.Lang

返回值:

类型 说明
T 返回排序第一的数据,为空时返回undefined。

错误码:

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

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

示例:

cpp 复制代码
let treeSet = new TreeSet();
treeSet.add("squirrel");
treeSet.add("sparrow");
let result = treeSet.getFirstValue();

getLastValue

getLastValue(): T

获取容器中排序最后的数据,为空时返回undefined。

系统能力: SystemCapability.Utils.Lang

返回值:

类型 说明
T 返回排序最后的数据,为空时返回undefined。

错误码:

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

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

示例:

cpp 复制代码
let treeSet = new TreeSet();
treeSet.add("squirrel");
treeSet.add("sparrow");
let result = treeSet.getLastValue();

add

add(value: T): boolean

向容器中添加一组数据。

系统能力: SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
value T 添加的成员数据。

返回值:

类型 说明
boolean 成功添加新数据至容器返回true,否则返回false。

错误码:

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

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

示例:

cpp 复制代码
let treeSet = new TreeSet();
let result = treeSet.add("squirrel");

remove

remove(value: T): boolean

删除指定的元素。

系统能力: SystemCapability.Utils.Lang

参数:

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

返回值:

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

错误码:

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

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

示例:

cpp 复制代码
let treeSet = new TreeSet();
treeSet.add("squirrel");
treeSet.add("sparrow");
let result = treeSet.remove("sparrow");

getLowerValue

getLowerValue(key: T): T

获取容器中比传入元素排序靠前一位的元素,为空时返回undefined。

系统能力: SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
key T 对比的元素值。

返回值:

类型 说明
T 返回排序中对比元素前一位的数据,为空时返回undefined。

错误码:

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

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

示例:

cpp 复制代码
let treeSet = new TreeSet();
treeSet.add("squirrel");
treeSet.add("sparrow");
treeSet.add("gander");
let result = treeSet.getLowerValue("sparrow");

getHigherValue

getHigherValue(key: T): T

获取容器中比传入元素排序靠后一位的元素,为空时返回undefined。

系统能力: SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
key T 对比的元素。

返回值:

类型 说明
T 返回排序中传入元素后一位的数据。为空时返回undefined。

错误码:

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

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

示例:

cpp 复制代码
let treeSet = new TreeSet();
treeSet.add("squirrel");
treeSet.add("sparrow");
treeSet.add("gander");
let result = treeSet.getHigherValue("sparrow");

popFirst

popFirst(): T

删除容器中排序最前的数据,为空时返回undefined。

系统能力: SystemCapability.Utils.Lang

返回值:

类型 说明
T 返回删除的数据,为空时返回undefined。

错误码:

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

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

示例:

cpp 复制代码
let treeSet = new TreeSet();
treeSet.add("squirrel");
treeSet.add("sparrow");
let result = treeSet.popFirst();

popLast

popLast(): T

删除容器中排序最后的数据,为空时返回undefined。

系统能力: SystemCapability.Utils.Lang

返回值:

类型 说明
T 返回删除的数据,为空时返回undefined。

错误码:

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

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

示例:

cpp 复制代码
let treeSet = new TreeSet();
treeSet.add("squirrel");
treeSet.add("sparrow");
let result = treeSet.popLast();

clear

clear(): void

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

系统能力: SystemCapability.Utils.Lang

错误码:

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

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

示例:

cpp 复制代码
let treeSet = new TreeSet();
treeSet.add("squirrel");
treeSet.add("sparrow");
treeSet.clear();

values

values(): IterableIterator<T>

返回包含此映射中键值的新迭代器对象。

系统能力: SystemCapability.Utils.Lang

返回值:

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

错误码:

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

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

示例:

cpp 复制代码
let treeSet = new TreeSet();
treeSet.add("squirrel");
treeSet.add("sparrow");
let iter = treeSet.values();
let temp = iter.next().value;
while(temp != undefined) {
  console.log("value:" + temp);
  temp = iter.next().value;
}

forEach

forEach(callbackFn: (value?: T, key?: T, set?: TreeSet<T>) => void, thisArg?: Object): void

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

系统能力: SystemCapability.Utils.Lang

参数:

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

callbackFn的参数说明:

参数名 类型 必填 说明
value T 当前遍历到的value元素。
key T 当前遍历到的key元素。
set TreeSet<T> 当前调用forEach方法的实例对象。

错误码:

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

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

示例:

cpp 复制代码
let treeSet = new TreeSet();
treeSet.add("sparrow");
treeSet.add("gull");
treeSet.forEach((value, key) => {
    console.log("value:" + value, "key:" + key);
});

entries

entries(): IterableIterator<[T, T]>

返回包含此映射中键值对的新迭代器对象。

系统能力: SystemCapability.Utils.Lang

返回值:

类型 说明
IterableIterator<[T, T]> 返回一个迭代器。

错误码:

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

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

示例:

cpp 复制代码
let treeSet = new TreeSet();
treeSet.add("squirrel");
treeSet.add("sparrow");
let iter = treeSet.entries();
let temp = iter.next().value;
while(temp != undefined) {
  console.log("key:" + temp[0]);
  console.log("value:" + temp[1]);
  temp = iter.next().value;
}

[Symbol.iterator]

Symbol.iterator\](): IterableIterator\ 返回一个迭代器,迭代器的每一项都是一个JavaScript对象,并返回该对象。 **系统能力:** SystemCapability.Utils.Lang **返回值:** | 类型 | 说明 | |-----------------------|----------| | IterableIterator\ | 返回一个迭代器。 | ![搜狗高速浏览器截图20240326151450.png](https://file.jishuzhan.net/article/1787289872248082434/e6dfdcc17aaf87596b0d8d8d57904f6a.webp) **错误码:** 以下错误码的详细介绍请参见[语言基础类库错误码](https://gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md "语言基础类库错误码")。 | 错误码ID | 错误信息 | |----------|---------------------------------------------| | 10200011 | The Symbol.iterator method cannot be bound. | **示例:** ```cpp let treeSet = new TreeSet(); treeSet.add("squirrel"); treeSet.add("sparrow"); // 使用方法一: for (let item of treeSet) { console.log("value:" + item); } // 使用方法二: let iter = treeSet[Symbol.iterator](); let temp = iter.next().value; while(temp != undefined) { console.log("value:" + temp); temp = iter.next().value; } ``` ## 鸿蒙Next核心技术分享 ### 1、鸿蒙基础知识←[《鸿蒙NEXT星河版开发学习文档》](https://docs.qq.com/doc/DUlNzQU5CV1JmUGlG "《鸿蒙NEXT星河版开发学习文档》") ![](https://file.jishuzhan.net/article/1787289872248082434/1d2aa7ea03466c25d35f29cb9c0d7b08.webp) ### 2、鸿蒙ArkUI←[《鸿蒙NEXT星河版开发学习文档》](https://docs.qq.com/doc/DUlNzQU5CV1JmUGlG "《鸿蒙NEXT星河版开发学习文档》") ### ![](https://file.jishuzhan.net/article/1787289872248082434/c2d3841c09109a882bd488536d020838.webp) ### 3、鸿蒙进阶技术←[《鸿蒙NEXT星河版开发学习文档》](https://docs.qq.com/doc/DUlNzQU5CV1JmUGlG "《鸿蒙NEXT星河版开发学习文档》") ### ![](https://file.jishuzhan.net/article/1787289872248082434/5966f527623bf208b2a6020d1ea58ea2.webp) ### 4、鸿蒙就业高级技能←[《鸿蒙NEXT星河版开发学习文档》](https://docs.qq.com/doc/DUlNzQU5CV1JmUGlG "《鸿蒙NEXT星河版开发学习文档》") ![](https://file.jishuzhan.net/article/1787289872248082434/bac18a163bccd726e496e333f4e93583.webp) ### 5、鸿蒙多媒体技术←[《鸿蒙NEXT星河版开发学习文档》](https://docs.qq.com/doc/DUlNzQU5CV1JmUGlG "《鸿蒙NEXT星河版开发学习文档》") ![](https://file.jishuzhan.net/article/1787289872248082434/16e5ec25bf5c306b062cdc2eb3a20a73.webp) ### 6、鸿蒙南向驱动开发←[《鸿蒙NEXT星河版开发学习文档》](https://docs.qq.com/doc/DUlNzQU5CV1JmUGlG "《鸿蒙NEXT星河版开发学习文档》") ![](https://file.jishuzhan.net/article/1787289872248082434/47bbbd9d10860d321d66009dc2a58508.webp) ### 7、鸿蒙南向内核设备开发←[《鸿蒙NEXT星河版开发学习文档》](https://docs.qq.com/doc/DUlNzQU5CV1JmUGlG "《鸿蒙NEXT星河版开发学习文档》") ![](https://file.jishuzhan.net/article/1787289872248082434/e05fd06ec46f202f4602b8e87e9af129.webp) ### 8、鸿蒙系统裁剪与移植←[《鸿蒙NEXT星河版开发学习文档》](https://docs.qq.com/doc/DUlNzQU5CV1JmUGlG "《鸿蒙NEXT星河版开发学习文档》") ![](https://file.jishuzhan.net/article/1787289872248082434/5b0ea7565a22af4cce9107610df9d2f0.webp)

相关推荐
进击的圆儿3 小时前
鸿蒙应用(医院陪诊系统)开发篇1·主页面的tabs布局
华为·harmonyos
冯志浩3 小时前
HarmonyOS - 组件内部状态管理装饰器:Local
harmonyos·掘金·金石计划
Huang兄5 小时前
鸿蒙-http 和 rcp 抓包,应该如何配置?
harmonyos·arkts·arkui
京东云开发者6 小时前
【前瞻技术布局】咖啡机器人:具身智能技术首阶段探索与实践
程序员
京东云开发者6 小时前
DeepSeek 正当红,聊聊大模型应用的四大关键要素和未来
程序员
环信即时通讯云7 小时前
实战|使用环信Flutter SDK构建鸿蒙HarmonyOS应用及推送配置
flutter·华为·harmonyos
_waylau7 小时前
【HarmonyOS NEXT+AI】问答 03:找不到 DevEco Studio Cangjie Plugin 下载链接?
华为·开源·harmonyos·仓颉
别说我什么都不会7 小时前
【仓颉三方库】 数据库驱动——mysqlclient-ffi
harmonyos
beolus8 小时前
服务化参数调优实战
人工智能·程序员
__Benco8 小时前
OpenHarmony - 小型系统内核(LiteOS-A)(七)
人工智能·harmonyos