Skip to main content

@terascope/utils / big-map / BigMap

Class: BigMap<K, V>

Avoid v8 maximum size for Map by spreading the cache across multiple Maps. This class has the same API as Map but minus more differences in ->set and ->forEach

Type parameters

Type parameter
K
V

Constructors

new BigMap()

new BigMap<K, V>(entries?): BigMap<K, V>

Parameters

ParameterType
entries?null | readonly readonly [K, V][]

Returns

BigMap<K, V>

Source

packages/utils/src/big-map.ts:19

Properties

maxMapSize

readonly maxMapSize: number

Source

packages/utils/src/big-map.ts:14


DEFAULT_MAX_SIZE

static DEFAULT_MAX_SIZE: number

In some cache settings key evictions may not be able to keep up with the addition of new keys, setting the max size at 8.7M keys solves this issue

Source

packages/utils/src/big-map.ts:12

Accessors

size

get size(): number

Returns

number

Source

packages/utils/src/big-map.ts:76

Methods

[iterator]()

[iterator](): IterableIterator<[K, V], any, any>

Returns

IterableIterator<[K, V], any, any>

Source

packages/utils/src/big-map.ts:123


clear()

clear(): void

Returns

void

Source

packages/utils/src/big-map.ts:63


delete()

delete(key): boolean

Parameters

ParameterType
keyK

Returns

boolean

Source

packages/utils/src/big-map.ts:50


entries()

entries(): IterableIterator<[K, V], any, any>

Returns

IterableIterator<[K, V], any, any>

Source

packages/utils/src/big-map.ts:102


forEach()

forEach(callbackFn, thisArg?): void

Parameters

ParameterType
callbackFn(value, key, map) => void
thisArg?unknown

Returns

void

Source

packages/utils/src/big-map.ts:90


get()

get(key): undefined | V

Parameters

ParameterType
keyK

Returns

undefined | V

Source

packages/utils/src/big-map.ts:43


has()

has(key): boolean

Parameters

ParameterType
keyK

Returns

boolean

Source

packages/utils/src/big-map.ts:36


keys()

keys(): IterableIterator<K, any, any>

Returns

IterableIterator<K, any, any>

Source

packages/utils/src/big-map.ts:109


set()

set(key, value): Map<K, V>

Parameters

ParameterType
keyK
valueV

Returns

Map<K, V>

Source

packages/utils/src/big-map.ts:26


values()

values(): IterableIterator<V, any, any>

Returns

IterableIterator<V, any, any>

Source

packages/utils/src/big-map.ts:116