0

我在 .proto 文件中的代码目前如下所示:

message Category {
    int64 CategoryID = 1;
}

message Categories {
    repeated Category cat = 1;
}

当我运行protoc --gogofaster_out=. *.proto输出时,我得到的是:

type Category struct {
    CategoryID int64
}

type Categories struct {
    Cat []*Category
}

但我真正想要的是:

type Category struct {
    CategoryID int64
}

type Categories []*Category

.proto 文件中的代码需要什么才能获得所需的输出?

4

1 回答 1

0

Protobuf 基本上是一种序列化结构化数据的机制。这意味着在发送原始“消息”之前,必须对其进行序列化。当您为不同的语言编译此原型时,它会生成适当的类(用于 c++/Java)、用于 Golang 的结构。在您的情况下,“type Categories []*Category”不是一条消息,而是一个无法序列化的独立实体。(我可以在这里更正)。请参阅 Protobuf 语言指南https://developers.google.com/protocol-buffers/docs/proto3

如果这里的意图是拥有一个 Category 类型的数组并对其进行序列化,则建议将其封装在消息中。

于 2019-11-21T04:47:11.133 回答