`
MoonMonster
  • 浏览: 36700 次
  • 性别: Icon_minigender_1
  • 来自: 长沙
社区版块
存档分类
最新评论

Java序列化的几种方式

阅读更多

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);
	}
}

 

1
3
分享到:
评论

相关推荐

    java序列化和反序列化的方法

    Java 序列化和反序列化是 Java 语言中的一种机制,用于将对象转换为字节流,以便在网络上传输或存储。序列化是将对象转换为字节流的过程,而反序列化是将字节流转换回对象的过程。 在 Java 中,序列化和反序列化是...

    java反序列化工具

    Java反序列化是一种将已序列化的对象状态转换回对象的过程,它是Java平台中持久化数据的一种常见方式。在Java应用程序中,序列化用于保存对象的状态以便稍后恢复,或者在网络间传输对象。然而,这个过程也可能引入...

    Java实现几种序列化方式总结

    以下是几种常见的Java序列化方式的详细解释: 1. **Java原生序列化** Java原生序列化是最基础的序列化方式,适用于Java标准库中的对象。要进行序列化,对象所属的类必须实现`Serializable`接口。这个过程通常涉及...

    java序列化原理与算法

    Java序列化的基本流程可以分为以下几步: 1. **类信息描述**:首先输出子类的类信息描述。 2. **字段信息描述**:接着描述子类中的字段信息。若字段为对象类型,则暂时用字符串指针表示。 3. **父类信息描述**:...

    java序列化实现演示

    Java序列化是Java平台中的一种标准机制,允许对象的状态被保存到磁盘或者在网络中进行传输,以便在后续的时间或地点恢复这些对象。这个过程包括两个主要操作:序列化(将对象转换为字节流)和反序列化(将字节流恢复...

    Java序列化的机制和原理

    Java序列化是Java平台提供的一种将对象转换为字节流,以便存储、在网络上传输或者在后续时间重新创建相同对象的机制。这是Java编程中一个非常重要的概念,尤其是在分布式环境和持久化存储中。让我们深入探讨一下Java...

    java 常用序列化和反序列化框架使用demo

    本篇将介绍几个常用的Java序列化和反序列化框架,并通过示例代码进行演示。 1. **Java标准序列化**: Java标准序列化通过实现`Serializable`接口来标记类可序列化。要序列化一个对象,可以使用`ObjectOutputStream...

    java序列化之protobuf

    Java序列化是将Java对象转换为字节流的过程,以便可以在网络上传输或存储在磁盘上。这使得数据能够跨不同的系统平台进行传输和持久化。Protocol Buffers(protobuf)是Google推出的一种高效、跨平台的数据序列化协议...

    Java反序列化安全漏洞防控

    Java反序列化安全漏洞是一种严重的安全威胁,它主要发生在Java程序处理序列化数据时。序列化是Java中的一种机制,可以将对象状态转换为字节流,以便存储或传输。反序列化则是将字节流恢复为Java对象的过程。 在Java...

    java反序列化利用程序UI版Beta1.1.rar

    1. **Java序列化机制**:Java对象序列化是通过实现`Serializable`接口来标记一个类可被序列化。`ObjectOutputStream`用于将对象写入流,`ObjectInputStream`用于从流中读取并反序列化对象。 2. **易受攻击的库**:...

    几种序列化的实现方法 java自带, Writable, Avro

    与Java序列化相比,它更加轻量级且性能更好。每个可序列化的类型(如IntWritable, Text等)都实现了`write()`和`readFields()`方法,用于写入和读取数据到DataOutput和DataInput流。然而,Writable接口有一些局限性...

    java序列化与反序列化

    Java序列化提供了两种主要的API用于操作对象流: 1. `ObjectOutputStream`: 这个类用于将Java对象写入 OutputStream,实现序列化。 2. `ObjectInputStream`: 它用于从 InputStream 读取对象,实现反序列化。 序列...

    如何正确的使用Java序列化技术

    Java序列化技术是一种强大的功能,它能够将对象的状态转化为字节流,以便在网络上传输或持久化到文件系统中。这一机制是Java远程方法调用(RMI)、企业JavaBeans(EJB)、Java Native Interface(JNNI)等关键技术的基础。...

    java反序列化利用程序UI版Beta1.1.zip

    Java反序列化是一种将已序列化的对象状态转换回对象的过程,通常用于持久化数据或在网络间传输对象。然而,这个过程也可能带来安全风险,因为恶意用户可以构造特殊的序列化数据来执行任意代码,这就是所谓的Java反序...

    Java序列化和反序列化

    ### Java序列化与反序列化的深入解析 #### 序列化的功能与意义 序列化是Java编程语言中的一项核心功能,其主要目的是将对象的状态转换为可以存储或传输的格式,便于持久化保存或网络传输。序列化并不涉及对象的...

    深入分析Java的序列化与反序列化

    本文通过分析ArrayList的序列化来介绍Java序列化的相关内容。主要涉及到以下几个问题:  怎么实现Java的序列化  为什么实现了java.io.Serializable接口才能被序列化  transient的作用是什么  怎么自定义序列...

    Java序列化(Serializable)与反序列化__1.docx

    Java序列化主要有以下几个应用场景: 1. 保存对象的状态:当需要将内存中的对象保存到文件或数据库中,以便后续恢复使用。 2. 网络传输:在网络通信中,可以通过序列化将对象转换为字节流,然后通过Socket进行传输。...

    Java序列化技术的探讨.pdf

    本文将介绍几种常用的Java序列化技术,并通过比较、分析这些技术在功能、序列化后的字节数和序列化、反序列化速度方面的差异,得出了在什么应用环境下应该如何选择序列化技术框架。 对象序列化概述 对象序列化是一...

Global site tag (gtag.js) - Google Analytics