Protocol Buffer的package和go_package说明

  1. protoc --proto_path=$GOPATH/src --proto_path=. --go_out=. ./*.proto
    a. 上面的句编译语句中,--proto_path用于表示要编译的proto文件所依赖的其他proto文件的查找位置,可以使用-I来替代。如果没有指定则从当前目录中查找。
    b. --go_out有两层含义,一层是输出的是go语言对应的文件;一层是指定生成的go文件的存放位置。
    c. --go_out=plugins=grpc:helloworld,这里使用了grpc插件。如果proto文件想在rpc中使用,可以在proto中定义接口如下:
    service SearchService {
      rpc Search(SearchRequest) returns (SearchResponse);
    }
    helloworld表示生成的文件存放地址。
  2. protoc --go_out=plugins=grpc:. --go_opt=paths=source_relative ./update.proto
    a. --go_opt表示生成go文件时候的目录选项,如上面写时表示生成的文件与proto在同一目录。
  3. import、go_package、package
    a. package主要是用于避免命名冲突的,不同的项目(project)需要指定不同的package。
    b. import,如果proto文件需要使用在其他proto文件中已经定义的结构,可以使用import引入。
    c. option go_package = "github.com/protocolbuffers/protobuf/examples/go/tutorialpb"; go_packge有两层意思,一层是表明如果要引用这个proto生成的文件的时候import后面的路径;一层是如果不指定--go_opt(默认值),生成的go文件存放的路径。
    d. 需要注意的是package和go_package的含义。在官方给的文档中,package和go_package的最后一个单词不一样:

    Protocol Buffer的package和go_package说明_第1张图片


    他们的含义分别是:package用于防止不同project之间定义了同名message结构的冲突,因为package名的一个作用是用于init方法中的注册:

    而当go_package存在时,其最后一个单词是生成的go文件的package名字:

    而当go_package不存在时,go文件件的package名字就变成了proto中package指定的名字了。

 

你可能感兴趣的:(go,golang,开发语言,后端)