Dsjslib
A library implementing several standard data structures and utilities, in JavaScript. Its written and tested using Node.js which is the target platform.
Install / Use
/learn @monmohan/DsjslibREADME
dsjslib
This is a collection of different data structures and utilities, implemented in JavaScript. Its written and tested using Node.js which is also the target platform.
API Documentation >>
Overview
-
New
- Bloom Filter - Probabilistic data structure to test whether an element is a member of a set.
-
Maps
- Sorted Maps: Maps sorted according to natural ordering of keys or by comparator function provided at creation time. Two different backing stores are available
- Tries Map optimized for prefix searching on string keys
- Multi-Valued Map supporting multiple values for a key
- MultiMap
- TreeMultiMap - In addition, Map is sorted on keys. Uses AVLTree as backing store
-
Queues
- Linked Deque - An optionally capacity constrained deque based on linked nodes
- Priority Queue - Priority Queue based on a Binary Heap
- Delay Queue - Queue of 'Delayed' items, item can only be taken when its delay has expired. For example usage see wiki: DelayQueue-for-Scheduled-Task-Management
-
Utilities
-
LRU Cache with Stats Google Guava inspired LRU cache. Reference: Google Guava. In-memory LRU cache implementation for Node, inspired by Google Guava Loading Cache . The cache is simpler since it doesn't have to deal with concurrent threads, but other functionality of Guava cache are captured like - Auto loader function - Removal listener - Auto expiry After Write (TTL) - Max Size and weight - Cache Stats recording For usage and overview see wiki: https://github.com/monmohan/dsjslib/wiki/LRU-Cache-Feature-and-usage-overview
-
BitSet - An array of bits with operations to set, examine and clear individual bits
-
CircularBuffer - A data structure that uses a single, fixed-size buffer as if it were connected end-to-end. When the buffer is filled, new data is written starting at the beginning of the buffer and overwriting the old.
-
Bloom Filter - Probabilistic data structure to test whether an element is a member of a set.
-
BTree - Self balancing generalized Search Tree
-
Installation
npm install dsjslib
Current version 0.6.14 is stable and thoroughly tested on Node v0.10
Related Skills
node-connect
343.1kDiagnose OpenClaw node connection and pairing failures for Android, iOS, and macOS companion apps
frontend-design
90.0kCreate distinctive, production-grade frontend interfaces with high design quality. Use this skill when the user asks to build web components, pages, or applications. Generates creative, polished code that avoids generic AI aesthetics.
openai-whisper-api
343.1kTranscribe audio via OpenAI Audio Transcriptions API (Whisper).
qqbot-media
343.1kQQBot 富媒体收发能力。使用 <qqmedia> 标签,系统根据文件扩展名自动识别类型(图片/语音/视频/文件)。
