protobuf 简单例子

protobuf的简单的例子,如下:

person.proto文件

    message Person{
        required string name = 1;
        required int32 age = 2;
        optional string email = 3;
        enum PhoneType{
            MOBILE = 1;
            HOME = 2;
            WORK = 3;
        }
        message Phone{
            required int32 id = 1;
            optional PhoneType type = 2 [default = HOME];
        }
        repeated string phoneNum = 4;  //对应于cpp的vector
    }

安装好protoc以后,执行protoc person.proto --cpp_out=. 生成 person.pb.h和person.pb.cpp

写文件(write_person.cpp):

     
    #include <iostream>
    #include "person.pb.h"
    #include <fstream>
    #include <string>
     
    using namespace std;
     
    int main(){
        string buffer;
        Person person;
        person.set_name("chemical");
        person.set_age(29);
        person.set_email("ygliang2009@gmail.com");
        person.add_phonenum("abc");
        person.add_phonenum("def");
        fstream output("myfile",ios::out|ios::binary);
        person.SerializeToString(&buffer); //用这个方法,通常不用SerializeToOstream
        output.write(buffer.c_str(),buffer.size());
        return 0;
    }

编译时要把生成的cpp和源文件一起编译,如下:g++ write_person.cpp person.pb.cpp -o write_person -I your_proto_include_path -L your_proto_lib_path -lprotoc -lprotobuf运行时记得要加上LD_LIBRARY_PATH=your_proto_lib_path

读文件(read_person.cpp):

     
     
    #include <iostream>
    #include "person.pb.h"
    #include <fstream>
    #include <string>
     
    using namespace std;
     
    int main(){
        Person *person = new Person;
        char buffer[BUFSIZ];
        fstream input("myfile",ios::in|ios::binary);
        input.read(buffer,sizeof(Person));
        person->ParseFromString(buffer);  //用这个方法,通常不用ParseFromString
        cout << person->name() << person->phonenum(0) << endl;
        return 0;
    }

编译运行方法同上:g++ read_person.cpp person.pb.cpp -o read_person -I your_proto_include_path -L your_proto_lib_path -lprotoc -lprotobuf
 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用protobuf-java的库来实现Java中的JSON转protobuf。下面是一个简单的示例代码: 首先,确保你已经安装了protobuf编译器,并且已经定义了你的protobuf消息类型和对应的.proto文件。 然后,在你的Java项目中引入protobuf-java的依赖: ```xml <dependency> <groupId>com.google.protobuf</groupId> <artifactId>protobuf-java</artifactId> <version>3.18.0</version> </dependency> ``` 接下来,你可以使用protobuf提供的JsonFormat类来进行JSON和protobuf消息类型之间的相互转换。下面是一个简单的示例代码: ```java import com.google.protobuf.InvalidProtocolBufferException; import com.google.protobuf.util.JsonFormat; public class JsonToProtobufExample { public static void main(String[] args) throws InvalidProtocolBufferException { // 从JSON字符串创建一个空的protobuf消息实例 MyProtoMessage.Builder messageBuilder = MyProtoMessage.newBuilder(); // 将JSON字符串解析并填充到protobuf消息实例中 String json = "{\"field1\": \"value1\", \"field2\": \"value2\"}"; JsonFormat.parser().merge(json, messageBuilder); // 将填充好的protobuf消息实例转换为字节数组 MyProtoMessage message = messageBuilder.build(); byte[] protobufBytes = message.toByteArray(); // 将字节数组转换为protobuf消息实例 MyProtoMessage parsedMessage = MyProtoMessage.parseFrom(protobufBytes); // 打印输出转换后的protobuf消息 System.out.println(parsedMessage); } } ``` 上述代码中,`MyProtoMessage`是你自己定义的protobuf消息类型,在使用时需要替换为你自己的类型。 通过以上代码,你可以将JSON字符串转换为protobuf消息实例,并将其序列化为字节数组。如果需要将protobuf消息实例转换回JSON字符串,你可以使用`JsonFormat.printer().printToString(message)`方法。 希望这能帮到你!如有任何疑问,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值