`
MoonMonster
  • 浏览: 35829 次
  • 性别: 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原生以流的方法进行的序列化、Json序列化、FastJson序列化、Protobuff序列化。有兴趣的可以了解一下。

    Java高级程序设计实战教程第五章-Java序列化机制.pptx

    5.2 相关知识 5.2.1 序列化的概念 5.2.2 序列化应用 5.2.3 序列化的几种方式 5.2.4 对象实现机制 Java高级程序设计实战教程第五章-Java序列化机制全文共15页,当前为第3页。 5.2.1 序列化的概念 将在内存中的各种...

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

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

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

    NULL 博文链接:https://oracle-api.iteye.com/blog/2370063

    Hprose与.NET中各种序列化方式的对比

    本文对比了Hprose、.NET BinaryFormatter、SoapFormatter、DataContractSerializer、DataContractJsonSerializer、NetDataContractSerializer这几种序列化方式。测试程序较长,后面以附件方式来提供。

    java 面试常见问题整理

    泛型 Java 泛型了解么?什么是类型擦除?介绍一下常用的通配符? 常用的通配符有哪些? 你的项目中哪里用到了泛型? 反射 何为反射?...Java 中 IO 流分为几种? 既然有了字节流,为什么还要有字符流?

    JedisSerialization:实现利用Jedis向Redis中写入和得到Java对象的几种序列化工具:JDK、XML、JSON、Protostuff

    JedisSerialization实现利用Jedis向Redis中写入和得到Java对象的几种序列化工具:JDK、XML、JSON、Protostuff

    JAVA基础,常见java基础问题.rar

    反序列化就是序列化的逆过程,把磁盘文件中或网络节点的二进制数据恢复成java对象的过程,通常是将二进制数据转换为对象。 序列化的应用场景:将对象存储在文件或数据库中,利用套接字在网络上进行对象传输,RMI...

    java面试过程当中遇到的一些题目

    6. 什么是java序列化,如何实现java序列化?(写一个实例) 10 7. 一个".java"源文件中是否可以包括多个类(不是内部类)?有什么限制? 10 8. 排序都有哪几种方法?请列举。用JAVA实现一个快速排序? 10 9. Overload...

    java面试题(面试 宝典)

    6. 什么是java序列化,如何实现java序列化?(写一个实例) 10 7. 一个".java"源文件中是否可以包括多个类(不是内部类)?有什么限制? 10 8. 排序都有哪几种方法?请列举。用JAVA实现一个快速排序? 10 9. Overload...

    java面向对象之JVM创建及分配策略方法详解.docx

    在Java中我们有几种方式可以创建一个新的对象呢?总共有以下几种方式: new关键字 反射 clone 反序列化 Unsafe.allocateInstance 为了便于说明和理解,下文仅针对new出来的对象进行讨论。

    Java后端+Java后端中级面试题

    什么是Java的序列化和反序列化?为什么它们在分布式系统中很重要? 解释什么是Java的设计模式,并列举几个常用的设计模式及其应用场景。 这些题目涵盖了Java开发中的核心概念和常见问题,帮助您准备面试。祝您面试...

    JAVA上百实例源码以及开源项目

     Java生成密钥、保存密钥的实例源码,通过本源码可以了解到Java如何产生单钥加密的密钥(myKey)、产生双钥的密钥对(keyPair)、如何保存公钥的字节数组、保存私钥到文件privateKey.dat、如何用Java对象序列化保存私钥...

    技术选型分享:JAVA中几种常用的RPC框架介绍.docx

    RPC是远程过程调用的简称,广泛应用在大规模分布式应用中,作用是有助于系统的垂直拆分...其他的框架结构也类似,区别在于对象的序列化方法,传输对象的通讯协议,以及注册中心的管理与failover设计(利用zookeeper)。

    Java大数据开发+Java大厂面试题

    什么是Java的序列化和反序列化?为什么它们在分布式系统中很重要? 解释什么是Java的设计模式,并列举几个常用的设计模式及其应用场景。 这些题目涵盖了Java开发中的核心概念和常见问题,帮助您准备面试。祝您面试...

    Java面试题+Java后端中级面试题

    什么是Java的序列化和反序列化?为什么它们在分布式系统中很重要? 解释什么是Java的设计模式,并列举几个常用的设计模式及其应用场景。 这些题目涵盖了Java开发中的核心概念和常见问题,帮助您准备面试。祝您面试...

    JAVA上百实例源码以及开源项目源代码

     Java生成密钥、保存密钥的实例源码,通过本源码可以了解到Java如何产生单钥加密的密钥(myKey)、产生双钥的密钥对(keyPair)、如何保存公钥的字节数组、保存私钥到文件privateKey.dat、如何用Java对象序列化保存私钥...

    java开源包11

    6、支持多种通信框架(Mina/Netty/Grizzly),支持多种序列化/反序列化(Java/Hessian/PB); 7、支持自定义通信协议,可完全替换NFS-RPC自带的协议。 淘宝开放平台JAVA版SDK top4java 设计原则 容易维护扩展(不...

    java开源包6

    6、支持多种通信框架(Mina/Netty/Grizzly),支持多种序列化/反序列化(Java/Hessian/PB); 7、支持自定义通信协议,可完全替换NFS-RPC自带的协议。 淘宝开放平台JAVA版SDK top4java 设计原则 容易维护扩展(不...

    java开源包9

    6、支持多种通信框架(Mina/Netty/Grizzly),支持多种序列化/反序列化(Java/Hessian/PB); 7、支持自定义通信协议,可完全替换NFS-RPC自带的协议。 淘宝开放平台JAVA版SDK top4java 设计原则 容易维护扩展(不...

Global site tag (gtag.js) - Google Analytics