我希望使用FlatBuffers序列化[][]byte
消息。鉴于无法嵌套FBS向量,看来这是可行的方法:
namespace msgfbs;
table SubmitMessage {
nonces:[Nonce];
}
table Nonce {
bytes:[ubyte];
}
现在要编写此结构,我最终编写了此函数:
func NewSubmitMessage(builder *fbs.Builder, nonces [][]byte) []byte {
builder.Reset()
nonceCount := len(nonces)
// Convert nonces to byte vectors
byteVectors := make([]fbs.UOffsetT, nonceCount)
for i, nonce := range nonces {
byteVectors[i] = builder.CreateByteVector(nonce)
}
// Create FBS Nonces
noncesFbs := make([]fbs.UOffsetT, nonceCount)
for i := range nonces {
msgfbs.NonceStart(builder)
msgfbs.NonceAddBytes(builder, byteVectors[i])
noncesFbs[i] = msgfbs.NonceEnd(builder)
}
// Create vector of FBS Nonces
msgfbs.SubmitMessageStartNoncesVector(builder, nonceCount)
for i := nonceCount - 1; i >= 0; i-- {
builder.PrependUOffsetT(noncesFbs[i])
}
noncesVector := builder.EndVector(nonceCount)
// Create message
msgfbs.SubmitMessageStart(builder)
msgfbs.SubmitMessageAddNonces(builder, noncesVector)
builder.Finish(msgfbs.SubmitMessageEnd(builder))
builder.PrependByte(Submit)
return builder.FinishedBytes()
}
我需要3个连续的for循环,最后包装我的消息。这是序列化[][]byte
的最简单方法吗?有没有更有效的方法来达到相同的目的?
答案 0 :(得分:1)
前两个for循环可以合并:您可以创建字节向量,然后创建包含该字节向量的表。您只是不能在开始/结束之间嵌套字节向量。
对于最后一个for循环,确实应该有一个辅助函数为您执行此操作(其他语言也存在)。如果Go中没有,请在FlatBuffers存储库中创建一个问题(或者更好的是PR)。