protobuf java数据类型_关于java中protobuf中序列化基本类型的原理探索及解决方案...

本文探讨了在Java中如何处理protobuf序列化,特别是对于没有.proto契约文件的String字符串类型。通过分析protobuf的varint编码和message定义,展示了如何手动序列化String,并提供了具体的Java实现代码。
摘要由CSDN通过智能技术生成

最近在做一些.net转java的开发工作,碰到了一些在C#中相对比较容易处理,但是在java中不是那么容易处理,或者说,处理方案不是那么明显的问题。Protobuf序列化就是其中一个。

问题背景是:线上有若干的C#的WCF服务需要调用,由于我们的应用是先切换的,在对方服务不改变的情况下,要能做到我们切换成java之后,能够实现访问的平滑过渡。其中一部分服务的请求有对应的.proto契约文件,利用protoc工具可以生成对应的java文件,从而利用生成的java的类代码里的parseFrom方法,实现protobuf序列化;但是偏偏碰到了一个请求参数是String字符串类型的服务,由于没有proto文件,所以就不能生成对应的类,更没有对应的parseFrom方法,出现了难题。

在C#中,原来采用的protobuf-net.dll这个库,里面可以采用如下方式对字符串类型 (或者其他基本类型)进行序列化:

public static string SerializeObject(T obj) where T : class

{

string result = "";

try{

using (MemoryStream stream = new MemoryStream()){

Serializer.Serialize(stream, obj);

result = System.Convert.ToBase64String(stream.ToArray());

//序列化方式

result = string.Format("{0}{1}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值