@bnaya/objectbuffer v0.0.0-a954c8a
ObjectBuffer: object-like API, backed by a sharedarraybuffer 👀
For Modern browsers and node.
Save, read and update plain javascript objects into ArrayBuffer (And not only TypedArrays), using regular javascript object api, without serialization/deserialization, or pre-defined schema.
In other words, It's an implementation of javascript objects in user-land.
That's enables us to transfer or share objects in-memory with WebWorker without additional memory or serialization
While the library is not 1.0, it is usable.
A core part of the library is an allocator, that allocates & free memory on the ArrayBuffer for us!
The allocator in use is @thi.ng/malloc, part of the amazing thi.ng/umbrella project
🐉🐉🐉 Adventurers Beware 🐉🐉🐉
Using this library, and workers in general, will not necessarily make you code faster.
First be sure where are your bottlenecks and if you don't have a better and more simple workaround.
I personally also really like what's going on around the main thread scheduling proposal and react userland scheduler that powers concurrent react
Quick example
import { createObjectBuffer, getUnderlyingArrayBuffer } from "@bnaya/objectbuffer";
const initialValue = {
foo: { bar: new Date(), arr: [1], nesting:{ WorksTM: true } }
};
// ArrayBuffer is created under the hood
const myObject = createObjectBuffer(
{},
// size in bytes
1024,
initialValue
);
const arrayBuffer = getUnderlyingArrayBuffer(myObject);
myObject.additionalProp = "new Value";
myObject.arr.push(2);Play with it (codesandbox)
See also main.js for shared memory example.
to run it: clone the repo, yarn install and yarn browser-playground
Getting involved
Participants is Adhere to the Code of Conduct.
The quickest way to get up and running is via and to run the tests.
Go over the contributing document.
Pick an issue with "good first" or "help wanted", or do some cool by your own!
Feel free to open an issue, or contact me directly at me@bnaya.net
API reference
Why
Exchanging plain objects with WebWorkers is done by serializing and copying the data to the other side.
for some use-cases, it's slow and memory expensive.ArrayBuffer can be transferred without a copy, and SharedArrayBuffer can be directly shared, but out of the box, it's hard to use ArrayBuffer as more than a TypedArray.
Why maybe not FlatBuffers
For many cases FlatBuffers is the right tool!
FlatBuffers requires full re-serialization when changing values. inside. The api is also more different than javascript objects.
Disclaimer / Motivation
I'm working on it mostly from personal interest, and i'm not using it for any project yet.
Before putting any eggs in the basket, please go over the implementation details document
What's working
- strings
- number
- objects (with nesting and all)
- arrays
- Date
- BigInt
- Internal references (
foo.bar2 = foo.barwill not create a copy, but a reference) - Automatic reference counting, to dispose a value you need to use the
disposeWrapperObjector to have WeakRef support - Internal equality between objects (
foo.bar === foo.barwill be true) - global lock for shared memory using Atomics (I hope its really working)
Caveats & Limitations
- Need to specify size for the
ArrayBuffer. When exceed that size, exception will be thrown. (Can be extended later with a utility function, but not automatically) - Size must be multiplication of 8
- Set, Map, Object keys can be only string or numbers. no symbols or other things
- You can't save objects with circularities (But you can create them on objectbuffer)
- No prototype chain. no methods on the objects
- Adding getters, setters, will not work/break the library
- deleting/removing the current key of Map/Set while iteration will make you skip the next key #60
- unreliable_sizeOf is unreliable due to hashmap array side depends on actual keys, Also It's an expensive operation sizeof removed
What's not working yet, but can be
bigintbigger than 64 bit
What's probably never going to work
- Anything that cannot go into
JSON.stringify Symbol
If you came this far, you better also look at:
2 years ago
2 years ago
4 years ago
4 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago