JAVA设计模式(原型模式)

一、概述

原型模式是用于创建重复的对象,同时又能保证性能。这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式。

这种模式是实现了一个原型接口,该接口用于创建当前对象的克隆。当直接创建对象的代价比较大时,则采用这种模式。例如,一个对象需要在一个高代价的数据库操作之后被创建。我们可以缓存该对象,在下一个请求时返回它的克隆,在需要的时候更新数据库,以此来减少数据库调用。


二、代码

1.创建一个实现了 Clonable 接口的抽象类。

public abstract class Sender implements Cloneable {
	
	
	protected String id ;
	
	protected String type;

	public String getId() {
		return id;
	}

	public void setId(String id) {
		this.id = id;
	}

	public String getType() {
		return type;
	}

	public void setType(String type) {
		this.type = type;
	}

	abstract void sendMessage();

	public Object clone() {
		Object clone = null;
		try {
			clone = super.clone();
		} catch (CloneNotSupportedException e) {
			e.printStackTrace();
		}
		return clone;
	}
}

2.创建扩展了上面抽象类的实体类。

public class MessageSender extends Sender {

	public MessageSender() {
		type = "message";
	}
	
	@Override
	void sendMessage() {
	  System.out.println("send a message");
		
	}
}

public class SMSSender extends Sender{

	
	public SMSSender() {
		type = "SMS";
	}
	@Override
	void sendMessage() {
		System.out.println("send a sms");
		
	}
}


3.创建一个类,获取实体类,并把它们存储在一个 Hashtable 中。

public class SenderCache {
	
	private static Hashtable
   
   
    
     senderMap = new Hashtable<>();
	
	public static Sender getSender(String sendreID){
		Sender sender = senderMap.get(sendreID);
		return (Sender) sender.clone();
	}
	
	/*每种情况需要进行数据库查询*/
	
	public static void loadCache(){
		MessageSender messageSender = new MessageSender();
		messageSender.setId("1");
		senderMap.put(messageSender.getId(),messageSender);
		
		SMSSender smsSender = new SMSSender();
		smsSender.setId("2");
		senderMap.put(smsSender.getId(),smsSender);
	}

}
   
   

4.测试

public class PrototypePatternDemo {
	public static void main(String[] args) {
		SenderCache.loadCache();
		
		MessageSender messageSender = (MessageSender) SenderCache.getSender("1");
		
		SMSSender smsSender = (SMSSender)SenderCache.getSender("2");
		
		System.out.println("Message:"+messageSender.getType());
		
		System.out.println("SMSSender:"+smsSender.getType());
	}

}


PS:
  • 浅拷贝对于要克隆的对象, 会复制其基本数据类型(包括String)的属性(本例中的typr属性)的给新的对象. 而对于非基本数据类型的属性(如集合属性), 仅仅复制一份引用给新产生的对象, 即新产生的对象和原始对象中的非基本数据类型的属性都指向的是同一个对象.
  • 深拷贝 对于要克隆的对象, clone出的非基本数据类型的属性(要求属性也实现了Cloneable接口, ArrayList就已经自带实现了)不再是和原对象指向同一个对象了, 而是一个新的clone出来的属性对象实例.

原型模式是一种创建型设计模式,它提供了一种创建复杂对象的方式。这种模式允许你通过创建一个现有的对象(称为“原型”)并复制该对象来创建新的对象实例。 ### Java 设计模式 - 原型模式简介 #### 定义与用途 原型模式允许通过拷贝现有对象快速创建新对象,并在新对象上应用必要的修改。这种方式尤其适用于需要大量创建相似对象的情况,而无需编写大量的重复代码。原型模式使得创建过程更加高效、易于管理和维护。 #### 结构组成 原型模式由以下几个关键部分组成: 1. **`Prototype` 接口**:定义了一个对象创建的标准接口,所有具体的对象都应该实现这个接口。这通常包含一个 `clone()` 方法,用于生成对象的一个副本。 2. **具体原型**:实现了 `Prototype` 接口的具体对象。每个对象都可以有自己的克隆实现策略。 3. **克隆工厂**(可选):提供了一个统一的接口来请求克隆,这可以进一步封装克隆的具体实现细节。 4. **克隆者(Clonee)**:实际负责克隆工作的内部类或方法,它调用具体的对象实现 `clone()` 方法来生成一个副本。 #### 实现步骤 下面是一个简单的原型模式实现例子: ```java public interface Prototype { Prototype clone(); } public class ConcretePrototype implements Prototype { private String name; public ConcretePrototype(String name) { this.name = name; } @Override public Prototype clone() { return new ConcretePrototype(this.name); } // 其他属性和方法... } ``` 在这个例子中,`ConcretePrototype` 类实现了 `Prototype` 接口,并提供了一个 `clone()` 方法来生成一个新的 `ConcretePrototype` 对象,其名字与原始对象相同。 #### 应用场景 原型模式常见于游戏开发、数据库表单生成、配置文件管理等领域。例如,在构建游戏时,你可以创建一个游戏角色的基本模板,然后根据玩家的选择克隆出特定的角色,这样可以避免重复的代码和提高代码的复用性。 --- ### 相关问题: 1. **如何选择合适的对象作为原型模式的起点?** - 要点在于选择那些能够代表一类对象并且具备基本结构的对象作为原型。 2. **原型模式和浅拷贝、深拷贝的区别是什么?** - 浅拷贝仅复制对象的引用或浅层次的数据结构;而深拷贝会递归地复制整个对象树及其所有嵌套对象。 3. **在哪些情况下不适合使用原型模式?** - 当对象的创建非常简单,不需要复杂的构造逻辑时;当克隆操作成本极高,如涉及大量资源消耗或计算密集时;或者是对安全性有极高标准需求的应用场合。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值