扩展Protobuf消息

时间:2015-03-25 18:21:11

标签: inheritance serialization protocol-buffers extends

我有许多不同的模式,但是每个模式都包含一组字段。我想知道是否有办法让不同的模式扩展父模式并继承其字段。例如,这就是我想要的:

message Parent {
    required string common1 = 0;
    optional string common2 = 1;
}

message Child1 { // can we extend the Parent?
    // I want common1, common2 to be fields here
    required int c1 = 2;
    required string c2 = 3;
}

message Child2 { // can we extend Parent?
    // I want common1, common2 to be fields here
    repeated int c3 = 2;
    repeated string c4 = 3;
}

这样,Child1和Child2也包含来自Parent的字段common1和common2(可能更多)。

这是可能的,如果是这样的话?

2 个答案:

答案 0 :(得分:4)

这不是您问题的确切答案,但我们可以做类似的事情来分享常见参数。

message Child1 { 
    required int c1 = 2;
    required string c2 = 3;
}

message Child2 { 
    required int c1 = 2;
    required string c2 = 3;
}

message Request {
    required string common1 = 0;
    optional string common2 = 1;
    oneof msg { Child1 c1 = 2; Child2 c2 = 3; }

}

其他选项是使用 extend 关键字

message Parent {
    required string common1 = 0;
    optional string common2 = 1;
}

message Child1 { 
    extend Parent
    {       
        optional Child1 c1 = 100;
    }

    required int c1 = 2;
    required string c2 = 3;
}

答案 1 :(得分:0)

尽管 protobuf 不直接支持继承,但在某些语言(例如 C#)中,您仍然可以使用部分类为服务/请求/回复等创建通用契约。

您可以创建生成的部分类,并让它继承/实现您的常见场景。

通过这种方式,您可以确保内部模型和服务中的通用合同。

但是请注意,这仅供内部使用,因为端点和 API 表面应该完全不考虑您的规范。