使用序列化和反序列化实现深拷贝

import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;

import model.User;
/***
 * Java的对象序列化是指将那些实现了Serializable接口的对象转换成一个字符序列,
 * 并能够在以后将这个字节序列完全恢复为原来的对象。
 * 这一过程甚至可通过网络进行,这意味着序列化机制能自动弥补不同操作系统之间的差异。
 * 只要对象实现了Serializable接口(记住,这个接口只是一个标记接口,不包含任何的方法
 * 如果我们想要序列化一个对象,首先要创建某些OutputStream(如FileOutputStream、ByteArrayOutputStream等),
 * 然后将这些OutputStream封装在一个ObjectOutputStream中。
 * 这时候,只需要调用writeObject()方法就可以将对象序列化,并将其发送给OutputStream
 * (记住:对象的序列化是基于字节的,不能使用Reader和Writer等基于字符的层次结构)。
 * 而饭序列的过程(即将一个序列还原成为一个对象),
 * 需要将一个InputStream(如FileInputstream、ByteArrayInputStream等)封装在ObjectInputStream内,
 * 然后调用readObject()即可。
 * @author Aaron
 *
 */
public class SerializableTest {
	public static void main(String[] args) throws IOException, ClassNotFoundException {
		User user = new User("wxt",12);
		//序列化操作1--FileOutputStream
        ObjectOutputStream oos1 = new ObjectOutputStream(new FileOutputStream("User.out"));
        oos1.writeObject("User storage By FileOutputStream ");
        oos1.writeObject(user);//必须所有引用的对象都实现序列化,否则抛出有java.io.NotSerializableException:这个异常
        oos1.close();
        
        //反序列化操作1---FileInputStream
        ObjectInputStream ois1 = new ObjectInputStream(new FileInputStream("User.out"));
        String s1 = (String)ois1.readObject();
        User w1 = (User)ois1.readObject();
        ois1.close();
        System.out.println("反序列化操作1之后");
        System.out.println(s1);
        System.out.println("w1:"+w1);
        System.out.println(w1==user);
        System.out.println(w1.name==user.name);
        
        //序列化操作2--ByteArrayOutputStream
        ByteArrayOutputStream byteOutStream = new ByteArrayOutputStream();
        ObjectOutputStream oos2 = new ObjectOutputStream(byteOutStream);
        oos2.writeObject("Worm storage By ByteOutputStream ");
        oos2.writeObject(user);
        oos2.flush();
        
        //反序列操作2--ByteArrayInputStream
        ByteArrayInputStream byteInStream = new ByteArrayInputStream(byteOutStream.toByteArray());
        ObjectInputStream ois2 = new ObjectInputStream(byteInStream);
        String s2 = (String)ois2.readObject();
        User w2 = (User)ois2.readObject();
        ois2.close();
        System.out.println("反序列化操作2之后");
        System.out.println(s2);
        System.out.println("w2:"+w2);
        System.out.println(w2==user);
        System.out.println(w2.name==user.name);
        //反序列化创建对象不会调用构造函数,是深拷贝
	}
}

import java.io.Serializable;

public class User implements Serializable{
	
	/**
	 * 
	 */
	private static final long serialVersionUID = -8891141754953651838L;

	public String name;
	
	public int age;

	public User(String name, int age) {
		System.out.println("构造方法");
		this.name = name;
		this.age = age;
	}
	
	
	
}

全部评论

相关推荐

05-19 20:18
已编辑
长沙理工大学 Java
给口饭吃吧QQ:应该回他怪不得在做hr呢,大学白上了
点赞 评论 收藏
分享
鸿雁于飞:1. 求职定位乱成一锅粥,直接劝退HR 你期望职位同时写了「项目经理/技术经理/交付经理」,这仨岗根本不是一个赛道!项目经理玩流程和干系人,技术经理玩架构和带技术团队,交付经理玩客户和回款,你仨全堆上,HR直接判定「这人自己都不知道自己要干啥,没核心竞争力」,直接扔简历。 ​ 2. 2年多的职业空窗期,一个字不提,纯纯自杀行为 金融行业最看重职业连贯性和背景干净,你2018年5月到2020年8月,整整2年3个月没上班,啥说明都没有!HR直接脑补你是不是有竞业限制、是不是创业失败、是不是有啥背调过不了的问题,直接不敢往下看,首轮就给你筛了,这是最致命的坑! ​ 3. 工作经历纯纯摆烂,干货全藏起来了 你每段工作就写个公司、职位、时间,干了啥、带了多大团队、出了啥核心成果、给公司赚了/省了多少钱,一个字没有,全堆到后面的项目里了。HR看简历就3秒,第一眼看不到你每段工作的价值,直接就划走了,根本不会翻你后面的项目。 ​ 4. 项目经验像个大杂烩,还全是bug 你堆了快10个项目,银行、证券、公安、政务、日本项目啥都有,跟个杂货铺一样,HR根本看不到你的核心优势在哪。而且项目连个起止时间都不写,谁知道你这是最近的标杆项目,还是10年前刚入行干的活?还有数据前后矛盾,一会说「零事故交付」,一会说「生产事故率降低50%」,HR一看就觉得你瞎包装,根本不信。 ​ 5. 15年经验的经理岗,还在写一线拧螺丝的活,层级完全错配 你都应聘经理级岗位了,简历里还在写自己写接口、写测试脚本、做前端开发这些一线执行的活,完全没写你怎么搭建管理体系、怎么带团队、怎么搞定甲方、怎么控项目风险、怎么拿经营结果,MBA的价值一点没体现出来。HR看完直接觉得:合着你干了15年,还是个高级开发,根本达不到经理岗的要求,直接pass。 ​ 6. AI风口完全没抓住,写了句空话等于没写 现在全行业都在卷AI+金融,人家招管理岗,都要能落地AI场景的人。你就写了句「深化Transformer与大模型底层技术研习」,纯纯空话,一点实际落地成果都没有,跟其他候选人比,完全没差异化优势,人家凭啥放着年轻能落地的不要,要你这个只学了理论的? 姐好好看看,然后改改简历吧,要专,要精,然后降低求职目标。希望你能早日拿到offer
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务