如何解决serde/bincode 如何序列化字节数组?
#[derive(Debug,Clone,Serialize,Deserialize,PartialEq,Eq,PartialOrd,Ord)]
struct Hash([u8; 32]);
let hash = Hash([1u8; 32]);
let hash_bin = bincode::serialize(&hash).unwrap();
assert_eq!(hash_bin,[1u8; 32]);
它是如何工作的?
根据 https://serde.rs/impl-serializer.html 的说法,有一个 serialize_bytes()
函数,但二进制代码版本为数据添加了一个长度。
fn serialize_bytes(self,v: &[u8]) -> Result<()> {
O::IntEncoding::serialize_len(self,v.len())?;
self.writer.write_all(v).map_err(Into::into)
}
代码(在上面)调用了 Serialize 中的什么函数,将 32 个字节序列化为没有长度前缀的自己?
上下文:我正在实现一个类型的客户序列化,我希望它(在某些情况下)序列化字节数组,以便 bincode 将它们编码为没有长度前缀的字节。这是一个问题,因为调用 serialize_bytes()
会添加一个长度前缀。
我想了解默认情况下如何序列化字节数组,因为我不知道调用哪种方法代替 serialize_bytes()
来获取没有长度前缀的字节。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。