原型模式和单例模式的区别


1.   定义上的区别

1.1.  原型模式

原型模式是在已指定对象的基础上,然后通过拷贝这些原型对象创建新的对象。

当要实例化的类是在运行时刻指定或者为了避免创建一个与产品类层次平行的工厂类层次时或者当一个类的实例只能有几个不同状态组合中的一种时 —— 建立相应数目的原型克隆它们可能比每次用合适的状态手工实例化该类更方便一些。 

1.2.  单例模式

单态设计模式的核心就是:将类的构造方法私有化,之后在类的内部产生实例化对象,并通过静态方法返回实例化对象的应用。

如果不希望一个类产生更多对象的情况下,必须使用单态模式,所谓单态就是在对象的入口处(构造方法)限制了对象的实例化操作。

2.   JAVA实现上的区别

2.1.  原型模式

   
   
  1. import java.util.ArrayList;  
  2.  
  3. class ConcretePrototype implements Cloneable {  
   
   
  1.  
  2.  
  3.     private String name;  
  4.     private ArrayList<String> nameList = new ArrayList<String>();  
  5.  
  6.     public ConcretePrototype(String name) {  
  7.         this.name = name;  
  8.         this.nameList.add(this.name);  
  9.     }  
  10.  
  11.     // 添加nameList中的对象  
  12.     public void setName(String name) {  
  13.         this.nameList.add(name);  
  14.     }  
  15.  
  16.     public ArrayList<String> getNameList() {  
  17.         return this.nameList;  
  18.     }  
  19.  
  20.     // 覆盖Object基类中的clone()方法,并扩大该方法的访问权限,具体化返回本类型  
  21.     public ConcretePrototype clone() {  
  22.         try {  
  23.             return (ConcretePrototype) super.clone();  
  24.         } catch (CloneNotSupportedException e) {  
  25.             e.printStackTrace();  
  26.         }  
  27.         return null;  
  28.     }  
  29. }  
  30.  
  31. public class TestConcretePrototype {  
  32.     public static void main(String args[]) {  
  33.         try {  
  34.             ConcretePrototype prototype = new ConcretePrototype("调用原型方法");  
  35.             // 通过clone获取一个拷贝  
  36.             System.out.println(prototype.getNameList());  
  37.             ConcretePrototype fromClone = prototype.clone();  
  38.             fromClone.setName("调用克隆方法");  
  39.             System.out.println(fromClone.getNameList());  
  40.         } catch (Exception e) {  
  41.             e.printStackTrace();  
  42.         }  
  43.     }  
  44. }  

2.2.  单例模式

2.2.1. 单利模式的通用代码

   
   
  1. class Singleton {  
  2.  
  3.     private Singleton() {  
  4.         // 将构造方法进行封装,私有化  
  5.         // 定义为private的,是为了不让Singleton在外部生成对象,这才能体现单例模式  
  6.     }  
  7.       
  8.     // 在内部产生本类的实例化对象  
  9.     // 注意这是private只供内部调用  
  10.     private static Singleton instance = new Singleton();  
  11.  
  12.     public static Singleton getInstance() {  
  13.         // 通过静态方法取得instance对象  
  14.         // 这里提供了一个供外部访问本class的静态方法,可以直接访问  
  15.         return instance;  
  16.     }  
  17.  
  18.     public static void setInstance(Singleton instance) {  
  19.         Singleton.instance = instance;  
  20.     }  
  21. }  
  22.  
  23. public class TestSingleton {  
  24.     public static void main(String args[]) {  
  25.         // 初始化  
  26.         Singleton s1 = null;  
  27.         Singleton s2 = null;  
  28.         // 实例化对象  
  29.         s1 = Singleton.getInstance();  
  30.         s2 = Singleton.getInstance();  
  31.         // 若相等则表示生成的对象是唯一的  
  32.         System.out.println(s1 == s2);  
  33.     }  
  34. }  

2.2.2. 懒汉似的单例模式

   
   
  1. class SingletonLazy {
  2. // 在内部产生本类的实例化对象
  3. private static SingletonLazy instance = null;
  4. private SingletonLazy() {
  5. }
  6. // 线程安全,确保内存中只有一个实例
  7. public static synchronized SingletonLazy getInstance() {
  8. // 这个方法比上边有所改进,不用每次都进行生成对象,只是第一次使用时生成实例
  9. if (instance == null) {
  10. instance = new SingletonLazy();
  11. }
  12. return instance;
  13. }
  14. }
  15. public class TestSingletonLazy {
  16. public static void main(String args[]) {
  17. // TODO Auto-generated method stub
  18. // 初始化
  19. SingletonLazy s1 = null;
  20. SingletonLazy s2 = null;
  21. // 实例化对象
  22. s1 = SingletonLazy.getInstance();
  23. s2 = SingletonLazy.getInstance();
  24. // 若相等则表示生成的对象是唯一的
  25. System.out.println(s1 == s2);
  26. }
  27. }

3.   Spring源码学习

3.1.  Spring的原型模式

   
   
  1. abstract class AbstractBeanDefinition extends BeanMetadataAttributeAccessor
  2. implements BeanDefinition, Cloneable {
  3. private String scope = SCOPE_DEFAULT;
  4. private boolean singleton = true;
  5. private boolean prototype = false;
  6. public void setScope(String scope) {
  7. this.scope = scope;
  8. this.singleton = SCOPE_SINGLETON.equals(scope)
  9. || SCOPE_DEFAULT.equals(scope);
  10. this.prototype = SCOPE_PROTOTYPE.equals(scope);
  11. }
  12. public String getScope() {
  13. return this.scope;
  14. }
  15. @Override
  16. public Object clone() {
  17. return cloneBeanDefinition();
  18. }
  19. public abstract AbstractBeanDefinition cloneBeanDefinition();
  20. }
  21. public class SpringAbstractBeanDefinition {
  22. }

3.2.  Spring的单例模式

 

 

 

   
   
  1. import java.util.HashMap;
  2. import java.util.Map;
  3. class SingletonBeanFactoryLocator implements BeanFactoryLocator {
  4. private static final Map<String, BeanFactoryLocator> instances = new HashMap<String, BeanFactoryLocator>();
  5. public SingletonBeanFactoryLocator(String resourceLocation) {
  6. }
  7. public static BeanFactoryLocator getInstance(String selector)
  8. throws BeansException {
  9. String resourceLocation = selector;
  10. // 线程安全,确保内存中只有一个实例
  11. synchronized (instances) {
  12. BeanFactoryLocator bfl = instances.get(resourceLocation);
  13. if (bfl == null) {
  14. bfl = new SingletonBeanFactoryLocator(resourceLocation);
  15. instances.put(resourceLocation, bfl);
  16. }
  17. }
  18. return getInstance(null);
  19. }
  20. }
  21. public class SpringSingletonBeanFactoryLocator {
  22. }
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值