rkyv (archive) is a zero-copy deserialization framework for Rust

Discord

Resources

Learning Materials

Documentation

Benchmarks

Sister Crates

Example

```rust use rkyv::{ archived_root, ser::{serializers::AllocSerializer, Serializer}, Archive, Deserialize, Infallible, Serialize, };

[derive(Archive, Deserialize, Serialize, Debug, PartialEq)]

struct Test { int: u8, string: String, option: Option>, }

let value = Test { int: 42, string: "hello world".to_string(), option: Some(vec![1, 2, 3, 4]), };

let mut serializer = AllocSerializer::<256>::default(); serializer .serializevalue(&value) .expect("failed to serialize value"); let bytes = serializer.intoserializer().into_inner();

let archived = unsafe { archivedroot::(&bytes[..]) }; asserteq!(archived.int, value.int); asserteq!(archived.string, value.string); asserteq!(archived.option, value.option);

let deserialized = Deserialize::::deserialize(archived, &mut Infallible) .expect("failed to deserialize value"); assert_eq!(deserialized, value); ```