#heap-memory #alignment #box #memory-alignment

no-std aligned_box

Allocate heap memory with user-specified alignment

3 unstable releases

0.3.0 Jun 8, 2024
0.2.1 Feb 27, 2021
0.2.0 Sep 1, 2020
0.1.0 Aug 23, 2020

#371 in Memory management

Download history 239/week @ 2025-10-29 356/week @ 2025-11-05 249/week @ 2025-11-12 270/week @ 2025-11-19 283/week @ 2025-11-26 405/week @ 2025-12-03 829/week @ 2025-12-10 515/week @ 2025-12-17 92/week @ 2025-12-24 269/week @ 2025-12-31 709/week @ 2026-01-07 570/week @ 2026-01-14 603/week @ 2026-01-21 633/week @ 2026-01-28 811/week @ 2026-02-04 962/week @ 2026-02-11

3,086 downloads per month
Used in 4 crates (2 directly)

MIT license

32KB
468 lines

aligned_box: Allocate aligned heap memory in Rust.

CI license crates.io docs.rs

This crate provides a wrapper around the Box type, which allows allocating heap memory with user-specified alignment.

Examples

Place value 17 of type i32 on the heap, aligned to 64 bytes:

use aligned_box::AlignedBox;
let b = AlignedBox::<i32>::new(64, 17);

Allocate memory for 1024 values of type f32 on the heap, aligned to 128 bytes. Values are initialized by their default value:

use aligned_box::AlignedBox;
let b = AlignedBox::<[f32]>::slice_from_default(128, 1024);

Allocate memory for 1024 values of type f32 on the heap, aligned to 128 bytes. All values are initialized with PI:

use aligned_box::AlignedBox;
let b = AlignedBox::<[f32]>::slice_from_value(128, 1024, std::f32::consts::PI);

No runtime deps