java原生序列接口

我们都知道java中实现序列化和反序列化,一般只需要实现接口Serializable即可。

一.序列化,反序列化

1.定义:

序列化:将数据分解成字节流,以便存储在文件中或在网络上传输。

反序列化;就是打开字节流并重构对象。对象序列化不仅要将基本数据类型转换成字节表示,有时还要恢复数据。恢复数据要求有恢复数据的对象实例。

2java中序列化特点:

如果某个类能够被序列化,其子类也可以被序列化。声明为static和transient类型的成员数据不能被序列化。因为static代表类的状态, transient代表对象的临时数据。

3.应用场景:

1):远程通信

对象序列化可以进行远程通信,作为信息进行传递,实现分布式对象

主要应用例如:RMI要利用对象序列化运行远程主机上的服务,就像在本地机上运行对象时一样,这就是远程过程调用RPC
2):对象深拷贝

对象序列化不仅保留一个对象的数据,而且递归保存对象引用的每个对象的数据。可以将整个对象层次写入字节流中,可以保存在文件中或在网络连接上传递。利用对象序列化可以进行对象的"深复制",即复制对象本身及引用的对象本身。序列化一个对象可能得到整个对象序列。


二.实例

1.复杂pojo类

 

import java.io.Serializable;
import java.util.ArrayList;
import java.util.Map;
public class User implements Serializable{
private static final long serialVersionUID=1l;
public String username="";
public int id=0;
public ArrayList<Link>link=null;
public Map result=null;
// setter and getter省略
}
import java.io.Serializable;

public class Link implements Serializable {
private static final long serialVersionUID=3412341234l;
public String name="";
public String phone="";

// setter and getter省略

}
2.序列化,反序列化(对象深拷贝)

   public class myUtil{ 
   //序列化
   public static <T extends Serializable> byte[] objToByte(T obj) throws IOException{
        ByteArrayOutputStream out = new ByteArrayOutputStream();  
        ObjectOutputStream obs = new ObjectOutputStream(out);  
        obs.writeObject(obj);
        obs.close();
        byte[] b=out.toByteArray();
		return b;  
    }
   //反序列化
     public static <c extends Serializable> c byteToObj(byte[] bytes,Class c) throws Exception{
        ByteArrayInputStream ios = new ByteArrayInputStream(bytes);  
        ObjectInputStream ois = new ObjectInputStream(ios);  
        //返回生成的新对象  
        c obj = (c) ois.readObject();  
        ois.close();  
    	return obj;
    }

3.主程序

public class client{ 
public static void setUser(User user){
    	user.setId(1);
    	user.setUsername("xiaoxiang");
    	Link lk=new Link();
    	lk.setName("rongrong");
    	lk.setPhone("1234234");
    	Link lk1=new Link();
    	lk1.setName("rongrong");
    	lk1.setPhone("1234234");
    	ArrayList<Link> list=new ArrayList();
    	list.add(lk1);
    	list.add(lk);
    	user.setLink(list);
    	Map map=new HashMap();
    	map.put("123",lk);
    	map.put("234",lk1);
    	user.setResult(map);
    }
   public static void main(String[]args){
	   User user=new User();
	   setUser(user);
	   byte[]b=myUtil.objToByte(user);
           User myuser=myUtil.byteToObj(b,User.class);
           Link lk=(Link) myuser.getResult().get("123");
	   System.out.println("link name-----------"+lk.getName());
   }
}
执行结果如下:

link name-----------rongrong

三.总结
java中自带的序列化机制的效率不是很高,所以一般很难用在大型开源项目上,比如hadoop,实现了一个新的序列化机制。比java轻量,而且效率高。目前一些开源的序列化工具如 jackson,google开发Gson。但是这些工具在将复杂对象转化为json字符串时很方便,但是反序列化为对象时,效果一般。一般的pojo对象是可以用jackson等来解决的。但是如果一个对象很复杂,包含多层引用对象时,这些第三方包往往表现的不好,很难直接反序列化成对象,所以java中序列化接口的学习还是有必要的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值