Java基础之序列化对象Serialized

Java基础之序列化对象Serialized文章目录序列化对象Serialized目的:序列化类型应用场景代码案例直接应用自定义对象序列化序列化对象Serialized目的:序列化机制允许将实现序列化的Java对象转换成字节序列,这些字节序列可以被保存在磁盘上,或者通过网络传输,以备以后重新恢复成原来的对象.序列化类型对象的序列化(serialize)指将一个Java对象写入IO流中对象的反序列化机制(Deserialize)则指从IO流中恢复该Java对象.应用场景当你想把的内存中的对象保存到一个文件中或者数据库中时候;

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

序列化对象Serialized

目的:

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

序列化类型

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

应用场景

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

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

代码案例

直接应用

  • 将对象序列化
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();
	}
}
  • 反序列化对象
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();
	}
}

自定义对象序列化

  • 自定义对象类
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 + "]";
	}
	
}
  • 自定义对象序列化
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();
	}
}
  • 自定义对象的反序列化
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.net/149649.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月24日 下午5:16
下一篇 2022年6月24日 下午5:16


相关推荐

  • CEGUI环境的搭配[通俗易懂]

    CEGUI环境的搭配[通俗易懂]提前准备工具及安装包:1、CMake:一款编译工具下载地址2、CEGUI的源码及依赖项第一个箭头所指,代表是Windows系统的源码包,第二个则是Unix和Linux系统的源码包。配置环境步骤(针对windows平台,图形化操作)Linux下,或者Windows下dos命令也可以完成相应操作,输入相关命令即可。将源码包以及依赖项进行解压如:然后打…

    2022年7月24日
    12
  • 基于RAG与LangGraph的多模态智能问答系统——设计、实现与开源

    基于RAG与LangGraph的多模态智能问答系统——设计、实现与开源

    2026年3月15日
    2
  • Python字符串中删除特定字符的方法

    Python字符串中删除特定字符的方法这篇文章主要介绍了Python字符串中删除特定字符的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧分析在Python中,字符串是不可变的。所以无法直接删除字符串之间的特定字符。所以想对字符串中字符进行操作的时候,需要将字符串转变为列表,列表是可变的,这样就可以实现对字符串中特定字符的操作。1、删除特定字符特定字符…

    2022年6月10日
    75
  • .9图片报错Execution failed for task ‘:app:mergeDebugResources’. > Crunching Cruncher scrollbar_thumb.9.p

    .9图片报错Execution failed for task ‘:app:mergeDebugResources’. > Crunching Cruncher scrollbar_thumb.9.p

    2021年9月30日
    46
  • xsrf form html,python – tornado开启了xsrf_cookies,在ckeditor中上传文件如何传入xsrf_form_html()?…

    xsrf form html,python – tornado开启了xsrf_cookies,在ckeditor中上传文件如何传入xsrf_form_html()?…tornado在setting中设置了”xsrf_cookies”:True,则需要在表单中添加{%modulexsrf_form_html()%}。但ckeditor如何传xsrf_cookies这个值,每次上传图片都显示’_xsrf’argumentmissingfromPOST。如果把”xsrf_cookies”设置为False则上传成功。下面是上传的代码classcku…

    2022年5月12日
    36
  • Web渗透测试工具[通俗易懂]

    Web渗透测试工具[通俗易懂]一、介绍是用于攻击web应用程序的集成平台。它包含了许多Burp工具,这些不同的burp工具通过协同工作,有效的分享信息,支持以某种工具中的信息为基础供另一种工具使用的方式发起攻击。这些工具设计了许多接口,以促进加快攻击应用程序的过程。所有的工具都共享一个能处理并显示HTTP消息,持久性,认证,代理,日志,警报的一个强大的可扩展的框架。它主要用来做安全性渗透测试。二、下载安装 2.1地址 链接:https://pan.baidu.com/s/1xhQ…

    2022年8月12日
    10

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号