Crates.io | azul-peek-poke-derive |
lib.rs | azul-peek-poke-derive |
version | 0.2.1 |
source | src |
created_at | 2021-07-11 12:54:31.855825 |
updated_at | 2021-07-11 12:54:31.855825 |
description | Derive macro for peek-poke. |
homepage | |
repository | https://github.com/servo/webrender |
max_upload_size | |
id | 421401 |
size | 24,538 |
Peek from and poke structures into byte slices.
Below are the benchmark results of comparison between peek-poke
and bincode
serializing and deserializing same struct
:
struct MyPeekPokeStruct {
a: u8,
b: u16,
c: MyPeekPokeEnum,
d: Option<usize>,
}
enum MyPeekPokeEnum {
Variant1,
Variant2(u16),
}
Benchmarking struct::serialize/peek_poke::poke_into: Collecting 100 samples in struct::serialize/peek_poke::poke_into
time: [2.7267 ns 2.7321 ns 2.7380 ns]
Benchmarking struct::serialize/bincode::serialize: Collecting 100 samples in est struct::serialize/bincode::serialize
time: [31.264 ns 31.326 ns 31.389 ns]
Benchmarking struct::deserialize/peek_poke::peek_from: Collecting 100 samples struct::deserialize/peek_poke::peek_from
time: [5.3544 ns 5.3672 ns 5.3817 ns]
Benchmarking struct::deserialize/bincode::deserialize: Collecting 100 samples in struct::deserialize/bincode::deserialize
time: [25.155 ns 26.439 ns 27.661 ns]
You can run benchmarks by running following command:
cargo bench
Licensed under either of
at your option.
see LICENSE-APACHE, LICENSE-MIT for details.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as about, without any additional terms or conditions.