前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Java基础之序列化对象Serialized

Java基础之序列化对象Serialized

作者头像
全栈程序员站长
发布2022-09-12 11:38:54
4040
发布2022-09-12 11:38:54
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是你们的朋友全栈君。

文章目录

序列化对象Serialized

目的:

  • 序列化机制允许将实现序列化的Java对象转换成字节序列 ,这些字节序列可以被保存在磁盘上,或者通过网络传输,以备以后重新恢复成原来的对象.

序列化类型

  • 对象的序列化(serialize)指将一个Java对象写入IO流中
  • 对象的反序列化机制(Deserialize)则指从IO流中恢复该Java对象.

应用场景

  • 当你想把的内存中的对象保存到一个文件中或者数据库中时候;
  • 当你想用套接字在网络上传送对象的时候;

对于一般的类型都会实现该Serialized接口,例如:String、Data所以我们可以直接用。

代码案例

直接应用

  • 将对象序列化
代码语言:javascript
复制
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.ObjectOutputStream;
import java.util.Date;
/** * 序列化对象(Serializable) * 将对象的状态信息转换为可以存储或传输的形式的过程。 * @author wenhua * */
public class ObjectOutDate { 
   
public static void main(String[] args) throws IOException { 
   
	// 封装文件目录:即将序列化对象保存的文件
	FileOutputStream out = new FileOutputStream("object.txt");
	// 创建序列化对象
	ObjectOutputStream oout = new ObjectOutputStream(out);
	// 将需要序列化的对象写入该文件
	oout.writeObject(new Date());// date包已经实现了Serializable接口所以直接保存
	// 关闭资源
	oout.close();
	}
}
  • 反序列化对象
代码语言:javascript
复制
import java.io.FileInputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.util.Date;

/** * 反序列化对象(即创建一个对象) * 序列化的对象Date、String已经实现了implements java.io.Serializable * @author wenhua * */
public class ObjectInDate { 
   
	public static void main(String[] args) throws Exception, IOException { 
   
		// 封装文件
		FileInputStream inputStream = new FileInputStream("object.txt");
		// 创建反序列化对象:即输出流
		ObjectInputStream oin = new ObjectInputStream(inputStream);
		// 接收对象
		Date date = (Date) oin.readObject();
		// 输出文件
		System.out.println(date);// Tue May 19 17:44:23 CST 2020
		// 关闭资源
		oin.close();
	}
}

自定义对象序列化

  • 自定义对象类
代码语言:javascript
复制
import java.io.Serializable;

/** * 实现序列化接口的对象 * 注意:需要显示的声明序列化id号,不然当类信息改变时系统生成的id号就会改变 * transient/static关键字修饰的不被序列化 * @author wenhua * */
public class User implements Serializable { 
   

	/** * 为类生成一个版本号,序列化ID */
	private static final long serialVersionUID = 1L;
	private int sum;
	private String name;
	private transient Integer age;
	private static Integer code;
	
	public User() { 
   
		super();
	}
	
	public User(int sum, String name,Integer age,Integer code) { 
   
		super();
		this.sum = sum;
		this.name = name;
		this.age = age;
		this.code = code;
	}

	@Override
	public String toString() { 
   
		return "User [sum=" + sum + ", name=" + name + ", age=" + age + ", code=" + code + "]";
	}
	
}
  • 自定义对象序列化
代码语言:javascript
复制
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.ObjectOutputStream;

/** * 使用自定义对象的序列化 * @author wenhua * */
public class ObjectOutUser { 
   
public static void main(String[] args) throws IOException { 
   
	// 封装文件
	FileOutputStream out = new FileOutputStream("user.txt");
	// 创建序列化对象流
	ObjectOutputStream oout = new ObjectOutputStream(out);
	// 创建对象
	User jim = new User(100,"Jim",21,1);
	// 存储对象
	oout.writeObject(jim);
	// 关闭资源
	oout.close();
	}
}
  • 自定义对象的反序列化
代码语言:javascript
复制
import java.io.FileInputStream;
import java.io.IOException;
import java.io.ObjectInputStream;

/** * 反序列化自定义对象 * @author wenhua * */
public class ObjectInUser { 
   
	public static void main(String[] args) throws Exception, IOException { 
   
		// 封装文件目录
		FileInputStream inputStream = new FileInputStream("user.txt");
		// 创建反序列化对象流
		ObjectInputStream oin = new ObjectInputStream(inputStream);
		// 接收对象
		User user = (User)oin.readObject();// 注意重写toString方法
		
		System.out.println(user);// User [sum=100, name=tom, age=null, code=null]
		// 关闭资源
		oin.close();
	}
}

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/149649.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 文章目录
  • 序列化对象Serialized
    • 目的:
      • 序列化类型
        • 应用场景
          • 代码案例
            • 直接应用
            • 自定义对象序列化
        相关产品与服务
        文件存储
        文件存储(Cloud File Storage,CFS)为您提供安全可靠、可扩展的共享文件存储服务。文件存储可与腾讯云服务器、容器服务、批量计算等服务搭配使用,为多个计算节点提供容量和性能可弹性扩展的高性能共享存储。腾讯云文件存储的管理界面简单、易使用,可实现对现有应用的无缝集成;按实际用量付费,为您节约成本,简化 IT 运维工作。
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档