我注意到,当我尝试使用 Borsh 来 serialize/deserialize 时,我会遇到错误
I notice when I try and use Borsh to serialize/deserialize I'll get errors
我注意到当我尝试使用 Borsh 来 serialize/deserialize 当数据大小不匹配时我会得到错误。例如,如果我在帐户数据中有一个数组,然后我会尝试添加另一个元素。如果我还没有占位符数据项,其中字段中有虚拟值,序列化尝试将失败。是我做错了什么,还是事情就是这样,我只能接受?
如果您将数据的 &[u8] 传递给 try_from_slice 但总体帐户数据大小大于您的数据,您将收到 borsh 错误,因为它默认使用整体切片长度(或类似长度):
- 通过获取 try_to_vec() 输出的 .len() 来捕获您正在存储的数据的实际大小,并将其写入帐户数据块,然后存储您的数据。反序列化时,使用存储的 len 并使用它从帐户数据创建一个该大小的切片以传递给 try_from_slice。您可以在此处 https://github.com/hashblock/solana-cli-program-template/blob/main/program/src/account_state.rs 在 L66(序列化)和 L85(反序列化)处看到一个示例(使用 BTreeMap 而不是您的数组,但您明白了)。
我注意到当我尝试使用 Borsh 来 serialize/deserialize 当数据大小不匹配时我会得到错误。例如,如果我在帐户数据中有一个数组,然后我会尝试添加另一个元素。如果我还没有占位符数据项,其中字段中有虚拟值,序列化尝试将失败。是我做错了什么,还是事情就是这样,我只能接受?
如果您将数据的 &[u8] 传递给 try_from_slice 但总体帐户数据大小大于您的数据,您将收到 borsh 错误,因为它默认使用整体切片长度(或类似长度):
- 通过获取 try_to_vec() 输出的 .len() 来捕获您正在存储的数据的实际大小,并将其写入帐户数据块,然后存储您的数据。反序列化时,使用存储的 len 并使用它从帐户数据创建一个该大小的切片以传递给 try_from_slice。您可以在此处 https://github.com/hashblock/solana-cli-program-template/blob/main/program/src/account_state.rs 在 L66(序列化)和 L85(反序列化)处看到一个示例(使用 BTreeMap 而不是您的数组,但您明白了)。