1.自己定义方法
优点:不同预先设置缓存大小
缺点:不方便阅读,以及编写
package com.chalmers.change; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.util.Arrays; /** * @author Chalmers 2016年2月22日 下午2:55:02 */ public class Change { public static void main(String[] args) throws IOException { Change c = new Change(); int id = 101; int age = 20; ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); //将属性写入 byteArrayOutputStream.write(c.int2Byte(id)); byteArrayOutputStream.write(c.int2Byte(age)); //转换成字节数组 byte[] buf = byteArrayOutputStream.toByteArray(); System.out.println(Arrays.toString(buf)); ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream( buf); //转换 byte[] id_byte = new byte[4]; byteArrayInputStream.read(id_byte); System.out.println("id: " + c.byte2Int(id_byte)); byte[] age_byte = new byte[4]; byteArrayInputStream.read(age_byte); System.out.println("age: " + c.byte2Int(age_byte)); } // 将int转换成byte类型 public byte[] int2Byte(int i) { byte[] bytes = new byte[4]; bytes[0] = (byte) (i >> 3 * 8); bytes[1] = (byte) (i >> 2 * 8); bytes[2] = (byte) (i >> 1 * 8); bytes[3] = (byte) (i >> 0 * 8); return bytes; } // 将byte转换成int类型 public int byte2Int(byte[] bytes) { return bytes[0] << 3 * 8 | bytes[1] << 2 * 8 | bytes[2] << 1 * 8 | bytes[3] << 0 * 8; } }
2.使用NIO中的ByteBuffer方法
优点:使用方便,不用引入额外的jar包
缺点:需要预先设置缓冲大小,不然会报错
package com.chalmers.change; import java.nio.ByteBuffer; import java.util.Arrays; /** * @author Chalmers * 2016年2月22日 下午9:33:59 */ /** * 将数据序列化 * 优点:使用方便,不用引入额外的jar包 * 缺点:需要预先设置缓冲大小,不然会报错 */ public class Change2 { public static void main(String[] args) { int id = 101; int age = 20; //设置空间大小为8 ByteBuffer byteBuffer = ByteBuffer.allocate(8); //将变量存入 byteBuffer.putInt(id); byteBuffer.putInt(age); //转成字节数组 byte[] buf = byteBuffer.array(); System.out.println(Arrays.toString(buf)); //将字节数组放入byteBuffer中 ByteBuffer byteBuffer2 = ByteBuffer.wrap(buf); //一个个的读出来 System.out.println("id: "+byteBuffer2.getInt()); System.out.println("age: "+byteBuffer2.getInt()); } }
3.1使用netty3的jar包中的ChannelBuffer类
这段代码只测试了简单的int类型,double等类型,而String类型需要额外的一些步骤,所以单独编写了。
优点:操作方便,不用预先设置大小
缺点:需要引入netty3的jar包
package com.chalmers.change; import java.util.Arrays; import org.jboss.netty.buffer.ChannelBuffer; import org.jboss.netty.buffer.ChannelBuffers; /** * @author Chalmers 2016年2月22日 下午9:42:37 */ /** * 序列化 * 优点:操作方便,不用预先设置大小 * 缺点:需要引入netty3的jar包 */ public class Change3 { public static void main(String[] args) { int id = 101; int age = 20; ChannelBuffer channelBuffer = ChannelBuffers.dynamicBuffer(); channelBuffer.writeInt(id); channelBuffer.writeInt(age); byte[] buf = new byte[channelBuffer.writerIndex()]; channelBuffer.readBytes(buf); System.out.println(Arrays.toString(buf)); ChannelBuffer wrappedBuffer = ChannelBuffers.wrappedBuffer(buf); System.out.println("id: "+wrappedBuffer.readInt()); System.out.println("age: "+wrappedBuffer.readInt()); } }
3.2使用netty3的jar包中的ChannelBuffer类
这段代码测试的是将String类型序列化
package com.chalmers.change; import java.util.Arrays; import org.jboss.netty.buffer.ChannelBuffer; import org.jboss.netty.buffer.ChannelBuffers; /** * @author Chalmers 2016年2月23日 下午3:44:16 */ public class Change4 { public static void main(String[] args) { String username = "Chalmers"; String password = "20134714"; ChannelBuffer channelBuffer = ChannelBuffers.dynamicBuffer(); //将字符串序列化跟其他不同,需要写写一个字符串的长度,然后再把字符串转成字节数组输入 //写入长度 channelBuffer.writeShort((short) username.length()); //写入字节数组 channelBuffer.writeBytes(username.getBytes()); channelBuffer.writeShort((short) password.length()); channelBuffer.writeBytes(password.getBytes()); //将Buffer转成字节数组 byte[] bytes = channelBuffer.array(); //输出 System.out.println(Arrays.toString(bytes)); //新建一个Buffer对象,并且把字节数组加载进来 ChannelBuffer channelBuffer2 = ChannelBuffers.wrappedBuffer(bytes); //感觉不太好,用int更方便,虽然short比int少占用两个字节 // 在反序列化字符串前,先读取字符串的长度 short len = channelBuffer2.readShort(); //构造字节数组 byte[] bytes2 = new byte[(int) len]; //将数据读取到字节数组汇中 channelBuffer2.readBytes(bytes2); String username2 = new String(bytes2); len = channelBuffer2.readShort(); byte[] bytes3 = new byte[(int) len]; channelBuffer2.readBytes(bytes3); String password2 = new String(bytes3); System.out.println(username2 + "\t" + password2); } }
相关推荐
本篇文章主要介绍了Java实现几种序列化方式总结,包括Java原生以流的方法进行的序列化、Json序列化、FastJson序列化、Protobuff序列化。有兴趣的可以了解一下。
5.2 相关知识 5.2.1 序列化的概念 5.2.2 序列化应用 5.2.3 序列化的几种方式 5.2.4 对象实现机制 Java高级程序设计实战教程第五章-Java序列化机制全文共15页,当前为第3页。 5.2.1 序列化的概念 将在内存中的各种...
本文通过分析ArrayList的序列化来介绍Java序列化的相关内容。主要涉及到以下几个问题: 怎么实现Java的序列化 为什么实现了java.io.Serializable接口才能被序列化 transient的作用是什么 怎么自定义序列...
NULL 博文链接:https://oracle-api.iteye.com/blog/2370063
本文对比了Hprose、.NET BinaryFormatter、SoapFormatter、DataContractSerializer、DataContractJsonSerializer、NetDataContractSerializer这几种序列化方式。测试程序较长,后面以附件方式来提供。
泛型 Java 泛型了解么?什么是类型擦除?介绍一下常用的通配符? 常用的通配符有哪些? 你的项目中哪里用到了泛型? 反射 何为反射?...Java 中 IO 流分为几种? 既然有了字节流,为什么还要有字符流?
JedisSerialization实现利用Jedis向Redis中写入和得到Java对象的几种序列化工具:JDK、XML、JSON、Protostuff
反序列化就是序列化的逆过程,把磁盘文件中或网络节点的二进制数据恢复成java对象的过程,通常是将二进制数据转换为对象。 序列化的应用场景:将对象存储在文件或数据库中,利用套接字在网络上进行对象传输,RMI...
6. 什么是java序列化,如何实现java序列化?(写一个实例) 10 7. 一个".java"源文件中是否可以包括多个类(不是内部类)?有什么限制? 10 8. 排序都有哪几种方法?请列举。用JAVA实现一个快速排序? 10 9. Overload...
6. 什么是java序列化,如何实现java序列化?(写一个实例) 10 7. 一个".java"源文件中是否可以包括多个类(不是内部类)?有什么限制? 10 8. 排序都有哪几种方法?请列举。用JAVA实现一个快速排序? 10 9. Overload...
在Java中我们有几种方式可以创建一个新的对象呢?总共有以下几种方式: new关键字 反射 clone 反序列化 Unsafe.allocateInstance 为了便于说明和理解,下文仅针对new出来的对象进行讨论。
什么是Java的序列化和反序列化?为什么它们在分布式系统中很重要? 解释什么是Java的设计模式,并列举几个常用的设计模式及其应用场景。 这些题目涵盖了Java开发中的核心概念和常见问题,帮助您准备面试。祝您面试...
Java生成密钥、保存密钥的实例源码,通过本源码可以了解到Java如何产生单钥加密的密钥(myKey)、产生双钥的密钥对(keyPair)、如何保存公钥的字节数组、保存私钥到文件privateKey.dat、如何用Java对象序列化保存私钥...
RPC是远程过程调用的简称,广泛应用在大规模分布式应用中,作用是有助于系统的垂直拆分...其他的框架结构也类似,区别在于对象的序列化方法,传输对象的通讯协议,以及注册中心的管理与failover设计(利用zookeeper)。
什么是Java的序列化和反序列化?为什么它们在分布式系统中很重要? 解释什么是Java的设计模式,并列举几个常用的设计模式及其应用场景。 这些题目涵盖了Java开发中的核心概念和常见问题,帮助您准备面试。祝您面试...
什么是Java的序列化和反序列化?为什么它们在分布式系统中很重要? 解释什么是Java的设计模式,并列举几个常用的设计模式及其应用场景。 这些题目涵盖了Java开发中的核心概念和常见问题,帮助您准备面试。祝您面试...
Java生成密钥、保存密钥的实例源码,通过本源码可以了解到Java如何产生单钥加密的密钥(myKey)、产生双钥的密钥对(keyPair)、如何保存公钥的字节数组、保存私钥到文件privateKey.dat、如何用Java对象序列化保存私钥...
6、支持多种通信框架(Mina/Netty/Grizzly),支持多种序列化/反序列化(Java/Hessian/PB); 7、支持自定义通信协议,可完全替换NFS-RPC自带的协议。 淘宝开放平台JAVA版SDK top4java 设计原则 容易维护扩展(不...
6、支持多种通信框架(Mina/Netty/Grizzly),支持多种序列化/反序列化(Java/Hessian/PB); 7、支持自定义通信协议,可完全替换NFS-RPC自带的协议。 淘宝开放平台JAVA版SDK top4java 设计原则 容易维护扩展(不...
6、支持多种通信框架(Mina/Netty/Grizzly),支持多种序列化/反序列化(Java/Hessian/PB); 7、支持自定义通信协议,可完全替换NFS-RPC自带的协议。 淘宝开放平台JAVA版SDK top4java 设计原则 容易维护扩展(不...