1# 共享容器 2<!--Kit: ArkTS--> 3<!--Subsystem: CommonLibrary--> 4<!--Owner: @lijiamin2025--> 5<!--Designer: @weng-changcheng--> 6<!--Tester: @kirl75; @zsw_zhushiwei--> 7<!--Adviser: @ge-yafang--> 8 9## ArkTS容器集 10 11ArkTS共享容器([@arkts.collections (ArkTS容器集)](../reference/apis-arkts/arkts-apis-arkts-collections.md))是一种在并发实例间共享传输的容器类,用于并发场景下的高性能数据传递。它的功能与Ecmascript 262规范定义的容器类似,但存在部分差异,具体可见[共享容器与原生API方法的行为差异对比](#共享容器与原生api方法的行为差异对比)。 12 13ArkTS共享容器在多个并发实例间传递时,默认采用引用传递,允许多个并发实例操作同一容器实例。此外,还支持拷贝传递,即每个并发实例拥有独立的ArkTS容器实例。 14 15ArkTS共享容器不是线程安全的,内部使用了fail-fast(快速失败)机制,即当检测到多个并发实例同时对容器进行结构性修改时,会触发异常。因此,在多线程场景下修改容器内属性时,开发者需要使用ArkTS提供的[异步锁](arkts-async-lock-introduction.md)机制保证ArkTS容器的安全访问。 16 17ArkTS共享容器包含如下几种:[Array](../reference/apis-arkts/arkts-apis-arkts-collections-Array.md)、[Map](../reference/apis-arkts/arkts-apis-arkts-collections-Map.md)、[Set](../reference/apis-arkts/arkts-apis-arkts-collections-Set.md)、TypedArray([Int8Array](../reference/apis-arkts/arkts-apis-arkts-collections-Int8Array.md)、[Uint8Array](../reference/apis-arkts/arkts-apis-arkts-collections-Uint8Array.md)、[Int16Array](../reference/apis-arkts/arkts-apis-arkts-collections-Int16Array.md)、[Uint16Array](../reference/apis-arkts/arkts-apis-arkts-collections-Uint16Array.md)、[Int32Array](../reference/apis-arkts/arkts-apis-arkts-collections-Int32Array.md)、[Uint32Array](../reference/apis-arkts/arkts-apis-arkts-collections-Uint32Array.md)、[Uint8ClampedArray](../reference/apis-arkts/arkts-apis-arkts-collections-Uint8ClampedArray.md)、[Float32Array](../reference/apis-arkts/arkts-apis-arkts-collections-Float32Array.md))、[ArrayBuffer](../reference/apis-arkts/arkts-apis-arkts-collections-ArrayBuffer.md)、[BitVector](../reference/apis-arkts/arkts-apis-arkts-collections-BitVector.md)、[ConcatArray](../reference/apis-arkts/arkts-apis-arkts-collections-ConcatArray.md),具体可见[@arkts.collections (ArkTS容器集)](../reference/apis-arkts/arkts-apis-arkts-collections.md)。 18 19容器集使用示例如下: 20 21```ts 22import { ArkTSUtils, collections, taskpool } from '@kit.ArkTS'; 23 24@Concurrent 25async function add(arr: collections.Array<number>, lock: ArkTSUtils.locks.AsyncLock) { 26 await lock.lockAsync(() => { // 如果不添加异步锁,任务会因为数据竞争冲突,导致抛异常失败 27 arr[0]++; 28 }) 29} 30 31@Entry 32@Component 33struct Index { 34 @State message: string = 'Hello World'; 35 36 build() { 37 RelativeContainer() { 38 Text(this.message) 39 .id('HelloWorld') 40 .fontSize(50) 41 .fontWeight(FontWeight.Bold) 42 .alignRules({ 43 center: { anchor: '__container__', align: VerticalAlign.Center }, 44 middle: { anchor: '__container__', align: HorizontalAlign.Center } 45 }) 46 .onClick(() => { 47 let taskGroup = new taskpool.TaskGroup(); 48 let lock = new ArkTSUtils.locks.AsyncLock(); 49 let arr = collections.Array.create<number>(1, 0); 50 let count = 1000; 51 let num = count; 52 while (num--) { 53 taskGroup.addTask(add, arr, lock); 54 } 55 taskpool.execute(taskGroup).then(() => { 56 console.info(`Return success: ${arr[0]} === ${count}`); 57 }).catch((e: Error) => { 58 console.error("Return error."); 59 }) 60 }) 61 } 62 .height('100%') 63 .width('100%') 64 } 65} 66``` 67<!-- @[example_use](https://gitcode.com/openharmony/applications_app_samples/blob/master/code/DocsSample/ArkTS/ArkTsConcurrent/ConcurrentThreadCommunication/InterThreadCommunicationObjects/SendableObject/SendableObjectRelated/entry/src/main/ets/managers/ArktsCollectionsIntroduction.ets) --> 68 69## 共享容器与原生API方法的行为差异对比 70 71ArkTS提供了Sendable数据相关的共享容器集,接口行为与原生API存在部分差异,具体见下文对比。 72 73> **说明:** 74> 75> ArkTS共享容器的类型与Ecmascript 262规范定义的原生容器类型不同,因此使用原生容器Array的isArray()方法判断collections.Array实例对象会返回false。 76> 77> ArkTS共享容器采用引用传递方式跨线程传递,与原生容器相比效率更高。如果需要跨线程传输大量数据,建议使用ArkTS共享容器。 78 79### Array 80 81支持通过[collections.Array.from](../reference/apis-arkts/arkts-apis-arkts-collections-Array.md#from)方法将原生容器Array转换为ArkTS Array容器;支持通过原生容器Array的from方法将 ArkTS Array容器转换为原生容器Array。 82 83| 原生API方法 | ArkTS容器集方法 | 是否有行为差异 | 在ArkTS容器中的差异表现 | 84| -------- | -------- | -------- | -------- | 85| length: number | readonly length: number | 是 | 为了防止undefined扩散,不允许设置length。 | 86| new(arrayLength ?: number): any[] | static create(arrayLength: number, initialValue: T): Array | 是 | 为了防止undefined扩散,构造函数中必须提供一个初始值。 | 87| new <T>(arrayLength: number): T[] | constructor() | 否 | 构造时传入的数据必须为Sendable类型,否则将导致编译错误。 | 88| new <T>(...items: T[]): T[] | constructor(first: T, ...left: T[]) | 是 | 为了防止undefined扩散,构造函数中必须提供一个初始值,继承场景下,无法调用该函数进行对象构造。 | 89| from<T>(arrayLike: ArrayLike<T>): T[] | static from<T>(arrayLike: ArrayLike<T>): Array<T> | 否 | / | 90| from<T, U>(iterable: Iterable<T> \| ArrayLike<T>, mapfn: (v: T, k: number) => U, thisArg?: any): U[] | static from<U, T>(arrayLike: ArrayLike<U> \| Iterable<U>, mapFn: ArrayFromMapFn<U, T>): Array<T> | 否 | / | 91| pop(): T \| undefined | pop(): T \| undefined | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 92| push(...items: T[]): number | push(...items: T[]): number | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 93| concat(...items: ConcatArray<T>[]): T[] | concat(...items: ConcatArray<T>[]): Array<T> | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 94| concat(...items: (T \| ConcatArray<T>)[]): T[] | concat(...items: ConcatArray<T>[]): Array<T> | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 95| join(separator?: string): string | join(separator?: string): string | 否 | / | 96| shift(): T \| undefined | shift(): T \| undefined | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 97| slice(start?: number, end?: number): T[] | slice(start?: number, end?: number): Array<T> | 否 | / | 98| sort(compareFn?: (a: T, b: T) => number): this | sort(compareFn?: (a: T, b: T) => number): Array<T> | 是 | 1. 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。<br/>2. 继承场景下,无法获得实际类型的返回值。 | 99| unshift(...items: T[]): number | unshift(...items: T[]): number | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 100| indexOf(searchElement: T, fromIndex?: number): number | indexOf(searchElement: T, fromIndex?: number): number | 否 | / | 101| forEach(callbackfn: (value: T, index: number, array: T[]) => void, thisArg?: any): void | forEach(callbackFn: (value: T, index: number, array: Array<T>) => void): void | 是 | ArkTS不支持this,因此不支持thisArg参数。 | 102| map<U>(callbackfn: (value: T, index: number, array: T[]) => U, thisArg?: any): U[] | map<U>(callbackFn: (value: T, index: number, array: Array<T>) => U): Array<U> | 是 | ArkTS不支持this,因此不支持thisArg参数。 | 103| filter(predicate: (value: T, index: number, array: T[]) => unknown, thisArg?: any): T[] | filter(predicate: (value: T, index: number, array: Array<T>) => boolean): Array<T> | 是 | ArkTS不支持this,因此不支持thisArg参数。 | 104| reduce(callbackfn: (previousValue: T, currentValue: T, currentIndex: number, array: T[]) => T): T | reduce(callbackFn: (previousValue: T, currentValue: T, currentIndex: number, array: Array<T>) => T): T | 否 | / | 105| reduce<U>(callbackfn: (previousValue: U, currentValue: T, currentIndex: number, array: T[]) => U, initialValue: U): U | reduce<U>(callbackFn: (previousValue: U, currentValue: T, currentIndex: number, array: Array<T>) => U, initialValue: U): U | 否 | / | 106| [n: number]: T | [index: number]: T | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 107| findIndex(predicate: (value: T, index: number, obj: T[]) => unknown, thisArg?: any): number | findIndex(predicate: (value: T, index: number, obj: Array<T>) => boolean): number | 是 | ArkTS不支持this,因此不支持thisArg参数。 | 108| fill(value: T, start?: number, end?: number): this | fill(value: T, start?: number, end?: number): Array<T> | 是 | 1. 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。<br/>2. 继承场景下,无法获得实际类型的返回值。 | 109| entries(): IterableIterator<[number, T]> | entries(): IterableIterator<[number, T]> | 否 | / | 110| keys(): IterableIterator<number> | keys(): IterableIterator<number> | 否 | / | 111| values(): IterableIterator<T> | values(): IterableIterator<T> | 否 | / | 112| includes(searchElement: T, fromIndex?: number): boolean | includes(searchElement: T, fromIndex?: number): boolean | 否 | / | 113| at(index: number): T \| undefined | at(index: number): T \| undefined | 否 | / | 114| isArray(arg: any): arg is any[] | static isArray(value: Object \| undefined \| null): boolean | 是 | 仅判断是否为ArkTS的Array实例,对原生容器Array返回false。| 115| of<T>(...items: T[]): T[] | static of<T>(...items: T[]): Array<T> | 否 | / | 116| copyWithin(target: number, start: number, end?: number): this | copyWithin(target: number, start: number, end?: number): Array<T> | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 117| lastIndexOf(searchElement: T, fromIndex?: number): number | lastIndexOf(searchElement: T, fromIndex?: number): number | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 118| some(predicate: (value: T, index: number, array: T[]) => unknown, thisArg?: any): boolean | some(predicate: ArrayPredicateFn<T, Array<T>>): boolean | 是 | 1. 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。<br/>2.ArkTS不支持this,因此不支持thisArg参数。| 119| reduceRight(callbackfn: (previousValue: T, currentValue: T, currentIndex: number, array: T[]) => T): T | reduceRight(callbackFn: ArrayReduceCallback<T, T, Array<T>>): T | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 120| reduceRight<U>(callbackfn: (previousValue: U, currentValue: T, currentIndex: number, array: T[]) => U, initialValue: U): U | reduceRight<U = T>(callbackFn: ArrayReduceCallback<U, T, Array<T>>, initialValue: U): U | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 121| reverse(): T[] | reverse(): Array<T> | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 122| toString(): string | toString(): string | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 123| find(predicate: (value: T, index: number, obj: T[]) => unknown, thisArg?: any): T \| undefined | find(predicate: (value: T, index: number, obj: Array<T>) => boolean): T \| undefined | 是 | 1. 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。<br/>2. ArkTS不支持this,因此不支持thisArg参数。| 124| splice(start: number, deleteCount: number, ...items: T[]): T[] | splice(start: number, deleteCount: number, ...items: T[]): Array<T> | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 125| every(predicate: (value: T, index: number, array: T[]) => unknown, thisArg?: any): boolean | every(predicate: ArrayPredicateFn<T, Array<T>>): boolean | 是 | ArkTS不支持this,因此不支持thisArg参数。| 126| toLocaleString(): string | toLocaleString(): string | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 127 128### ArrayBuffer 129 130| 原生API方法 | ArkTS容器集方法 | 是否有行为差异 | 在ArkTS容器中的差异表现 | 131| -------- | -------- | -------- | -------- | 132| readonly byteLength: number | readonly byteLength: number | 否 | / | 133| slice(begin: number, end?: number): ArrayBuffer | slice(begin: number, end?: number): ArrayBuffer | 否 | / | 134| new(byteLength: number): ArrayBuffer | constructor(byteLength: number) | 否 | / | 135 136### TypedArray(以Int8Array为例) 137 138支持通过[collections.Int8Array.from](../reference/apis-arkts/arkts-apis-arkts-collections-Int8Array.md#from-1)方法将原生容器Int8Array转换为ArkTS Int8Array容器;也支持通过原生容器 Int8Array的from方法将ArkTS Int8Array容器转换为原生容器Int8Array。 139 140| 原生API方法 | ArkTS容器集方法 | 是否有行为差异 | 在ArkTS容器中的差异表现 | 141| -------- | -------- | -------- | -------- | 142| readonly buffer: ArrayBufferLike | readonly buffer: ArrayBuffer | 否 | / | 143| readonly byteLength: number | readonly byteLength: number | 否 | / | 144| readonly byteOffset: number | readonly byteOffset: number | 否 | / | 145| readonly length: number | readonly length: number | 否 | / | 146| readonly BYTES_PER_ELEMENT: number | static readonly BYTES_PER_ELEMENT: number | 否 | / | 147| copyWithin(target: number, start: number, end?: number): this| copyWithin(target: number, start: number, end?: number): Int8Array | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 148| every(predicate: (value: number, index: number, array: Int8Array) => unknown, thisArg?: any): boolean | every(predicate: TypedArrayPredicateFn<number, Int8Array>): boolean | 是 | 1. 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。<br/>2. ArkTS不支持this,因此不支持thisArg参数。 | 149| fill(value: number, start?: number, end?: number): this | fill(value: number, start?: number, end?: number): Int8Array | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 150| filter(predicate: (value: number, index: number, array: Int8Array) => any, thisArg?: any): Int8Array | filter(predicate: TypedArrayPredicateFn<number, Int8Array>): Int8Array | 是 | 1. 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。<br/>2. ArkTS不支持this,因此不支持thisArg参数。 | 151| find(predicate: (value: number, index: number, obj: Int8Array) => boolean, thisArg?: any): number \| undefined | find(predicate: TypedArrayPredicateFn<number, Int8Array>): number \| undefined | 是 | 1. 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。<br/>2. ArkTS不支持this,因此不支持thisArg参数。 | 152| findIndex(predicate: (value: number, index: number, obj: Int8Array) => boolean, thisArg?: any): number | findIndex(predicate: TypedArrayPredicateFn<number, Int8Array>): number | 是 | ArkTS不支持this,因此不支持thisArg参数。 | 153| forEach(callbackfn: (value: number, index: number, array: Int8Array) => void, thisArg?: any): void | forEach(callbackFn: (value: number, index: number, array: Int8Array) => void): void | 是 | 1. 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。<br/>2. ArkTS不支持this,因此不支持thisArg参数。 | 154| indexOf(searchElement: number, fromIndex?: number): number | indexOf(searchElement: number, fromIndex?: number): number | 否 | / | 155| join(separator?: string): string | join(separator?: string): string | 否 | / | 156| map(callbackfn: (value: number, index: number, array: Int8Array) => number, thisArg?: any): Int8Array | map(callbackFn: TypedArrayForEachCallback<number, Int8Array>): Int8Array | 是 | 1. 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。<br/>2. ArkTS不支持this,因此不支持thisArg参数。 | 157| reduce(callbackfn: (previousValue: number, currentValue: number, currentIndex: number, array: Int8Array) => number): number | reduce(callbackFn: TypedArrayReduceCallback<number, number, Int8Array>): number | 否 | / | 158| reduce(callbackfn: (previousValue: number, currentValue: number, currentIndex: number, array: Int8Array) => number, initialValue: number): number | reduce(callbackFn: TypedArrayReduceCallback<number, number, Int8Array>, initialValue: number): number | 否 | / | 159| reduce<U>(callbackfn: (previousValue: U, currentValue: number, currentIndex: number, array: Int8Array) => U, initialValue: U): U | reduce<U>(callbackFn: TypedArrayReduceCallback<U, number, Int8Array>, initialValue: U): U | 否 | / | 160| reverse(): Int8Array | reverse(): Int8Array | 否 | / | 161| set(array: ArrayLike<number>, offset?: number): void | set(array: ArrayLike<number>, offset?: number): void | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作否则会抛出异常。 | 162| slice(start?: number, end?: number): Int8Array | slice(start?: number, end?: number): Int8Array | 否 | / | 163| some(predicate: (value: number, index: number, array: Int8Array) => unknown, thisArg?: any): boolean | some(predicate: TypedArrayPredicateFn<number, Int8Array>): boolean | 是 | ArkTS不支持this,因此不支持thisArg参数。 | 164| sort(compareFn?: (a: number, b: number) => number): this | sort(compareFn?: TypedArrayCompareFn<number>): Int8Array | 是 | 1. 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。<br/>2. 继承场景下,无法获得实际类型的返回值。 | 165| subarray(begin?: number, end?: number): Int8Array | subarray(begin?: number, end?: number): Int8Array | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 166| [index: number]: number | [index: number]: number | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 167| entries(): IterableIterator<[number, number]> | entries(): IterableIterator<[number, number]> | 否 | / | 168| keys(): IterableIterator<number> | keys(): IterableIterator<number> | 否 | / | 169| values(): IterableIterator<number> | values(): IterableIterator<number> | 否 | / | 170| includes(searchElement: number, fromIndex?: number): boolean | includes(searchElement: number, fromIndex?: number): boolean | 否 | / | 171| at(index: number): number \| undefined | at(index: number): number \| undefined | 否 | / | 172| new(length: number): Int8Array | constructor(length: number) | 否 | / | 173| new(array: ArrayLike<number> \| ArrayBufferLike): Int8Array | constructor(array: ArrayLike<number> \| ArrayBuffer) | 否 | / | 174| new(buffer: ArrayBufferLike, byteOffset?: number, length?: number): Int8Array | constructor(buffer: ArrayBuffer, byteOffset?: number, length?: number) | 否 | / | 175| from(arrayLike: ArrayLike<number>): Int8Array | static from(arrayLike: ArrayLike<number>): Int8Array | 否 | / | 176| from<T>(arrayLike: ArrayLike<T>, mapfn: (v: T, k: number) => number, thisArg?: any): Int8Array | static from<T>(arrayLike: ArrayLike<T>, mapFn: TypedArrayFromMapFn<T, number>): Int8Array | 是 | ArkTS不支持this,因此不支持thisArg参数。 | 177| from(arrayLike: Iterable<number>, mapfn?: (v: number, k: number) => number, thisArg?: any): Int8Array | static from(arrayLike: Iterable<number>, mapFn?: TypedArrayFromMapFn<number, number>): Int8Array | 是 | ArkTS不支持this,因此不支持thisArg参数。 | 178| of(...items: number[]): Int8Array | static of(...items: number[]): Int8Array | 否 | / | 179| toString(): string | toString(): string | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 180| toLocaleString(): string | toLocaleString(): string | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 181| lastIndexOf(searchElement: number, fromIndex?: number): number | lastIndexOf(searchElement: number, fromIndex?: number): number | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 182| reduceRight(callbackfn: (previousValue: number, currentValue: number, currentIndex: number, array: Int8Array) => number): number | reduceRight(callbackFn: TypedArrayReduceCallback<number, number, Int8Array>): number | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 183| reduceRight<U>(callbackfn: (previousValue: U, currentValue: number, currentIndex: number, array: Int8Array) => U, initialValue: U): U | reduceRight<U = number>(callbackFn: TypedArrayReduceCallback<U, number, Int8Array>, initialValue: U): U | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 184 185### Map 186 187| 原生API方法 | ArkTS容器集方法 | 是否有行为差异 | 在ArkTS容器中的差异表现 | 188| -------- | -------- | -------- | -------- | 189| readonly size: number | readonly size: number | 是 | 不允许在遍历或访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 190| clear(): void | clear(): void | 是 | 不允许在遍历或访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 191| delete(key: K): boolean | delete(key: K): boolean | 是 | 不允许在遍历或访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 192| forEach(callbackfn: (value: V, key: K, map: Map<K, V>) => void, thisArg?: any): void | forEach(callbackFn: (value: V, key: K, map: Map<K, V>) => void): void | 是 | 1. 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。<br/>2. ArkTS不支持this,因此不支持thisArg参数。 | 193| get(key: K): V \| undefined | get(key: K): V \| undefined | 是 | 不允许在遍历或访问过程中对元素进行增、删、改操作,否则将抛出异常。 | 194| has(key: K): boolean | has(key: K): boolean | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 195| set(key: K, value: V): this | set(key: K, value: V): Map<K, V> | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 196| entries(): IterableIterator<[K, V]> | entries(): IterableIterator<[K, V]> | 否 | / | 197| keys(): IterableIterator<K> | keys(): IterableIterator<K> | 否 | / | 198| values(): IterableIterator<V> | values(): IterableIterator<V> | 否 | / | 199| new <K, V>(entries?: readonly (readonly [K, V])[] \| null): Map<K, V> | constructor(entries?: readonly (readonly [K, V])[] \| null) | 是 | 构造时传入的k,v键值不能是非Sendable数据,否则编译会报错。 | 200 201### Set 202 203| 原生API方法 | ArkTS容器集方法 | 是否有行为差异 | 在ArkTS容器中的差异表现 | 204| -------- | -------- | -------- | -------- | 205| readonly size: number | readonly size: number | 是 | Sendable类和接口中不允许使用计算属性名称(arkts-sendable-compated-prop-name)。 | 206| add(value: T): this | add(value: T): Set<T> | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 207| clear(): void | clear(): void | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 208| delete(value: T): boolean | delete(value: T): boolean | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 209| forEach(callbackfn: (value: T, value2: T, set: Set<T>) => void, thisArg?: any): void | forEach(callbackFn: (value: T, value2: T, set: Set<T>) => void): void | 是 | 1. 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。<br/>2. ArkTS不支持this,因此不支持thisArg参数。 | 210| has(value: T): boolean | has(value: T): boolean | 是 | 不允许在遍历、访问过程中进行元素的增、删、改操作,否则会抛出异常。 | 211| entries(): IterableIterator<[T, T]> | entries(): IterableIterator<[T, T]> | 否 | / | 212| keys(): IterableIterator<T> | keys(): IterableIterator<T> | 否 | / | 213| values(): IterableIterator<T> | values(): IterableIterator<T> | 是 | Sendable类和接口中不允许使用计算属性名称(arkts-sendable-compated-prop-name)。 | 214| new <T = any>(values?: readonly T[] \| null): Set<T> | constructor(values?: readonly T[] \| null) | 是 | 构造时传入的数据必须为Sendable类型,否则将导致编译错误。 | 215