java通过java查询数据库一条数据库记录是为什么要用序列化声明id,它比int的优势在哪

本文着重讲解一下Java序列化的相关內容

如果对Java序列化感兴趣的同学可以研究一下。

一.Java序列化的作用

   有的时候我们想要把一个Java对象变成字节流的形式传出去有的时候我们想要从一个字节流中恢复一个Java对象。例如有的时候我们想要

把一个Java对象写入到硬盘或者传输到网路上面的其它计算机,这时我们就需要洎己去通过java把相应的对象写成转换成字节流对于这种通用

的操作,我们为什么不使用统一的格式呢没错,这里就出现了java的序列化的概念在Java的OutputStream类下面的子类ObjectOutput-

  为了更好的理解java序列化的应用,我举两个自己在开发项目中遇到的例子:

  1)在使用tomcat开发JavaEE相关项目的时候我们关闭tomcat后,楿应的session中的对象就存储在了硬盘上如果我们想要在tomcat重启的

时候能够从tomcat上面读取对应session中的内容,那么保存在session中的内容就必须实现相关的序列化操作

  2)如果我们使用的java对象要在分布式中使用或者在rmi远程调用的网络中使用的话,那么相关的对象必须实现java序列化接口

  亲爱的小伙伴,大概你已经了解了java序列化相关的作用接下来们来看看如何实现java的序列化吧。~

  二.实现java对象的序列化和反序列化

它定义了一种紧凑得鈳扩展得二进制协议格式,适合网络传输并且针对多个语言有不同得版本可供选择。

proto文件中的字段类型和java中的对应关系:

protobuf 在序列化和反序列化的时候是依赖于.proto文件生成的builder类完成,字段的变化如果不表现在.proto文件中就不会影响反序列化比较适合字段变化的情况。

做个测试:把UserVo序列化到文件中:

三种方式对比传输同样的数据google protobuf只有53个字节是最少的。结论:

跨语言、格式清晰一目了然

字节数比较大需要第三方类库
java原生方法不依赖外部类库 字节数比较大,不能跨语言
编写.proto配置用protoc工具生成对应的代码

我要回帖

更多关于 java查询数据库 的文章

 

随机推荐