1

我必须为一个大约有 12 种变体的对象生成一个原型类。所有 12 个变体共享四个相同的字段,然后具有特定的字段。在大多数情况下,非特定字段的数量将比公共字段多得多

我想知道实现这一目标的最有效方法是什么。

第一种选择:在通用原型类中定义通用字段,然后在所有特定类型中声明此类型的字段:

message CommonFields {
    // common_field1
    // ... common_fieldN
}

message SpecificType1 {
    CommonFields common = 1;
    // specific fields...
}

或者最好定义一个包含字段的顶级原型,然后有一个 oneof 字段,它可以引用包含特定字段的另一种类型:

message BaseType {
    // common_field_1
    // ... common_field_N
    oneof specific_fields {
        SpecificTypeFields1 type1_fields = N;
        SpecificTypeFields2 type1_fields = N+1;
    }
}

message SpecificTypeFields1 {
    // specific fields...
}

message SpecificTypeFields2 {
    // specific fields...
}

我对表演和惯例特别感兴趣。或者,如果有任何更典型的方式,例如只是重复公共字段。请记住,尽管我的原型只有 4 个公共字段,通常有 3-8 个特定字段。

4

1 回答 1

1

根据 protobuf 库,编码子消息通常会有一些性能损失。对于大多数库,比如 Google 自己的 protobuf 库,差别很小。使用任何一个选项,您最终都会对每条消息编码 1 个子消息,从而进一步减少影响。

我见过两种常用的格式。如果解码器端已经知道消息类型(例如来自 rpc 方法名称),聚合通常更容易实现,因为它不需要单独检查 oneof 类型。

但是,如果消息类型未知,则 oneof 方法更好,因为它可以轻松检测类型。

于 2019-03-16T18:40:51.280 回答