#stack-overflow #default-value #box #allocator #memcpy #debug-builds

no-std default-boxed

Helper trait to help create large struct on heap directly

13 releases

0.2.0 Mar 13, 2022
0.1.11 Mar 12, 2022
0.1.10 Aug 5, 2021
0.1.9 Jun 2, 2020
0.1.1 Aug 31, 2019

#210 in Memory management

Download history 229/week @ 2024-05-26 100/week @ 2024-06-02 77/week @ 2024-06-09 182/week @ 2024-06-16 319/week @ 2024-06-23 81/week @ 2024-06-30 108/week @ 2024-07-07 71/week @ 2024-07-14 139/week @ 2024-07-21 217/week @ 2024-07-28 123/week @ 2024-08-04 140/week @ 2024-08-11 345/week @ 2024-08-18 280/week @ 2024-08-25 500/week @ 2024-09-01 299/week @ 2024-09-08

1,434 downloads per month
Used in 5 crates (4 directly)

MIT license

8KB
60 lines

default-boxed

CI Crates.io

Helper trait to create instances of large structs with default value on heap directly without going through stack.

Similar to the unstable box syntax, it semantically doesn't require creating the whole struct on stack then moving to heap, and thus unlike copyless or boxext, it doesn't rely on optimization to eliminate building the struct on stack, which may still face stack overflow on debug build when creating large struct.

Example

use default_boxed::DefaultBoxed;

const BASE: usize = 1024;

#[derive(DefaultBoxed)]
struct Foo {
    a: Bar,
    b: [Bar; 1024 * BASE],
    c: [u32; 1024 * BASE],
}

struct Bar(u16);
impl Default for Bar {
    fn default() -> Bar {
        Bar(29)
    }
}

let foo = Foo::default_boxed();
assert_eq!(foo.a.0, 29);
assert_eq!(foo.b[128 * BASE].0, 29);
assert_eq!(foo.c[256 * BASE], 0);

let foo_arr = Foo::default_boxed_array::<16>();
assert_eq!(foo_arr[15].a.0, 29);

Dependencies

~1.5MB
~36K SLoC