Skip to content

Latest commit

 

History

History
94 lines (66 loc) · 4.29 KB

README.md

File metadata and controls

94 lines (66 loc) · 4.29 KB

Memories Project

*) NOT READY FOR PRODUCTION YET

Bugs Coverage Duplicated Lines (%) Lines of Code Maintainability Rating Reliability Rating Security Rating Vulnerabilities

Quality Gate Status Code Smells Technical Debt

About this project

Off-heap (Native) memory access for Java. Compatible with the old version of Java and not using sun.misc.Unsafe.

Consideration

  • netty-buffer API.

  • foreign-memory-access by Project Panama.

Usage

Note: Musl is required on Linux (malloc with musl is slow); consider to use mimaloc/jemalloc/others.
  • Allocate a block of memory
final MemoryAllocator allocator = new MemoryAllocatorApi(); // instantiate allocator.
final Memory memory = allocator.allocate(4); // Allocate 4 bytes block of memory.
  • Accessing memory
assert 0 == memory.writerIndex(); // initial writer index.
assert 0 == memory.readerIndex(); // initial reader index.
memory.writeInt(10); // write integer value to first 4 bytes will increase writer index.
assert 4 == memory.writerIndex(); // writer index after write 4 bytes data.
assert 0 == memory.readerIndex(); // writing data will not change reader index.
assert 10 == memory.readInt(); // read 4 bytes data based on current reader index.
assert 4 == memory.writerIndex(); // reading data will not change writer index.
assert 4 == memory.readerIndex(); // reader index after read 4 bytes data.
  • Convert to direct ByteBuffer
ByteBuffer buffer = (ByteBuffer) memory.as(ByteBuffer.class); // convert Memory to direct ByteBuffer without copying the buffer.
assert buffer.isDirect(); // should be direct buffer.
assert !buffer.isReadOnly(); // should be able to read or write.
  • Releasing memory
assert memory.release(); // Release 'memory' immediately without waiting 'memory' object GC'ed.
  • Wrap direct ByteBuffer into Memory
final ByteBuffer buffer = ByteBuffer.allocateDirect(4); // allocate direct ByteBuffer.
buffer.putInt(0, 10); // set integer value to first 4 bytes.
final Memory memory = allocator.wrap(buffer); // wrap direct ByteBuffer into Memory.
assert memory.capacity() == buffer.capacity(); // 'buffer' and 'memory' capacity should be same in size.
assert 10 == memory.getInt(0); // shared buffer between 'buffer' and 'memory'.
assert memory.release(); // release the buffer immediately without waiting both 'buffer' and 'memory' GC'ed.

License

The Memories Project is licensed under Apache-2.0.

SPDX-License-Identifier: Apache-2.0