如何在protobuff中获取具体类型的切片(不是指针)

nmi*_*nic 3 go protocol-buffers

对于原型:

syntax = "proto3";
package messagepb;

import "github.com/gogo/protobuf/gogoproto/gogo.proto";

option (gogoproto.marshaler_all) = true;
option (gogoproto.sizer_all) = true;
option (gogoproto.unmarshaler_all) = true;
option (gogoproto.goproto_getters_all) = false;

service KV {
  // Put puts the given key into the store.
  // A put request increases the revision of the store,
  // and generates one event in the event history.
  rpc Put(PutRequest) returns (PutResponse) {}
}

message PutRequest {
  bytes key = 1;
  bytes value = 2;
}

message ResponseHeader {
  repeated PutRequest l = 3;
}
Run Code Online (Sandbox Code Playgroud)

我得到以下原型结构:

type ResponseHeader struct {
    L     []*PutRequest `protobuf:"bytes,3,rep,name=l" json:"l,omitempty"`
}
Run Code Online (Sandbox Code Playgroud)

但是我如何遵循protostruct:

type ResponseHeader struct {
    L     []PutRequest `protobuf:"bytes,3,rep,name=l" json:"l,omitempty"`
}
Run Code Online (Sandbox Code Playgroud)

那就是我想拥有数据局部性(因此有连续数据的切片,而不是散布东西的指针)

nmi*_*nic 6

我需要使用:[(gogoproto.nullable)= false]如下所示:

repeated PutRequest l = 3 [(gogoproto.nullable) = false];
Run Code Online (Sandbox Code Playgroud)

并得到:

    L     []PutRequest `protobuf:"bytes,3,rep,name=l" json:"l"`
Run Code Online (Sandbox Code Playgroud)

  • 是的,我问了一个问题,然后几个小时后找到了解决方案 (2认同)