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 语言中的一种机制,用于将对象转换为字节流,以便在网络上传输或存储。序列化是将对象转换为字节流的过程,而反序列化是将字节流转换回对象的过程。 在 Java 中,序列化和反序列化是...
Java反序列化是一种将已序列化的对象状态转换回对象的过程,它是Java平台中持久化数据的一种常见方式。在Java应用程序中,序列化用于保存对象的状态以便稍后恢复,或者在网络间传输对象。然而,这个过程也可能引入...
以下是几种常见的Java序列化方式的详细解释: 1. **Java原生序列化** Java原生序列化是最基础的序列化方式,适用于Java标准库中的对象。要进行序列化,对象所属的类必须实现`Serializable`接口。这个过程通常涉及...
Java序列化的基本流程可以分为以下几步: 1. **类信息描述**:首先输出子类的类信息描述。 2. **字段信息描述**:接着描述子类中的字段信息。若字段为对象类型,则暂时用字符串指针表示。 3. **父类信息描述**:...
Java序列化是Java平台中的一种标准机制,允许对象的状态被保存到磁盘或者在网络中进行传输,以便在后续的时间或地点恢复这些对象。这个过程包括两个主要操作:序列化(将对象转换为字节流)和反序列化(将字节流恢复...
Java序列化是Java平台提供的一种将对象转换为字节流,以便存储、在网络上传输或者在后续时间重新创建相同对象的机制。这是Java编程中一个非常重要的概念,尤其是在分布式环境和持久化存储中。让我们深入探讨一下Java...
本篇将介绍几个常用的Java序列化和反序列化框架,并通过示例代码进行演示。 1. **Java标准序列化**: Java标准序列化通过实现`Serializable`接口来标记类可序列化。要序列化一个对象,可以使用`ObjectOutputStream...
Java序列化是将Java对象转换为字节流的过程,以便可以在网络上传输或存储在磁盘上。这使得数据能够跨不同的系统平台进行传输和持久化。Protocol Buffers(protobuf)是Google推出的一种高效、跨平台的数据序列化协议...
Java反序列化安全漏洞是一种严重的安全威胁,它主要发生在Java程序处理序列化数据时。序列化是Java中的一种机制,可以将对象状态转换为字节流,以便存储或传输。反序列化则是将字节流恢复为Java对象的过程。 在Java...
1. **Java序列化机制**:Java对象序列化是通过实现`Serializable`接口来标记一个类可被序列化。`ObjectOutputStream`用于将对象写入流,`ObjectInputStream`用于从流中读取并反序列化对象。 2. **易受攻击的库**:...
与Java序列化相比,它更加轻量级且性能更好。每个可序列化的类型(如IntWritable, Text等)都实现了`write()`和`readFields()`方法,用于写入和读取数据到DataOutput和DataInput流。然而,Writable接口有一些局限性...
Java序列化提供了两种主要的API用于操作对象流: 1. `ObjectOutputStream`: 这个类用于将Java对象写入 OutputStream,实现序列化。 2. `ObjectInputStream`: 它用于从 InputStream 读取对象,实现反序列化。 序列...
Java序列化技术是一种强大的功能,它能够将对象的状态转化为字节流,以便在网络上传输或持久化到文件系统中。这一机制是Java远程方法调用(RMI)、企业JavaBeans(EJB)、Java Native Interface(JNNI)等关键技术的基础。...
Java反序列化是一种将已序列化的对象状态转换回对象的过程,通常用于持久化数据或在网络间传输对象。然而,这个过程也可能带来安全风险,因为恶意用户可以构造特殊的序列化数据来执行任意代码,这就是所谓的Java反序...
### Java序列化与反序列化的深入解析 #### 序列化的功能与意义 序列化是Java编程语言中的一项核心功能,其主要目的是将对象的状态转换为可以存储或传输的格式,便于持久化保存或网络传输。序列化并不涉及对象的...
本文通过分析ArrayList的序列化来介绍Java序列化的相关内容。主要涉及到以下几个问题: 怎么实现Java的序列化 为什么实现了java.io.Serializable接口才能被序列化 transient的作用是什么 怎么自定义序列...
Java序列化主要有以下几个应用场景: 1. 保存对象的状态:当需要将内存中的对象保存到文件或数据库中,以便后续恢复使用。 2. 网络传输:在网络通信中,可以通过序列化将对象转换为字节流,然后通过Socket进行传输。...
本文将介绍几种常用的Java序列化技术,并通过比较、分析这些技术在功能、序列化后的字节数和序列化、反序列化速度方面的差异,得出了在什么应用环境下应该如何选择序列化技术框架。 对象序列化概述 对象序列化是一...