使用反序列化破解单例模式(不包含枚举式)

1.本章主要描叙使用反序列化来破解单例模式,代码还是使用反射破解单例模式上面的代码。

2.测试代码如下:

package com.xb.golf4;

import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.lang.reflect.Constructor;

/**
 * 单例模式测试
 * @author Xiebin
 *
 */
public class Test {
	public static void main(String[] args) throws Exception {
		SingletonDemo02 singleton01=SingletonDemo02.getInstance();
		SingletonDemo02 singleton02=SingletonDemo02.getInstance();
		System.out.println(singleton01==singleton02);
		System.out.println(singleton01);
		System.out.println(singleton02);
		FileOutputStream fos=new FileOutputStream("G:/b.txt");
		ObjectOutputStream oos=new ObjectOutputStream(fos);
		oos.writeObject(singleton02);
		oos.close();
		fos.close();
		
		ObjectInputStream ois=new ObjectInputStream(new FileInputStream("G:/b.txt"));
		SingletonDemo02 instatce02= (SingletonDemo02) ois.readObject();
		System.out.println(instatce02);
	}
}

3.需要注意的是SingletonDemo02类需要实现Serializable接口,结果如下:

4.如何防止这种情况的发生,需要在SingletonDemo02类中加入如下代码:

	//反序列化是,如果定义这个方法则直接会返回该对象
	private Object readResolve ()throws ObjectStreamException{
		
		return SingletonDemo02.getInstance();
	}

添加了这个方法后,就可以避免创建新的对象了,反序列化创建对象时就会直接得到这个方法返回的对象。结果如下:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值