这种情况有没有?有!大点声,有没有?有,是,确实有,就出现在明朝,那三国期间的算不算,不算,各自称帝,各有各的地盘,国号不同。大家还
记得那首诗《石灰吟》吗?作者是谁?于谦,他是被谁杀死的?明英宗朱祁镇,对,就是那个在土木堡之变中被瓦刺俘虏的皇帝,被俘虏后,他弟弟朱祁钰当上

了皇帝,就是明景帝,估计当上皇帝后乐疯了,忘记把老哥朱祁镇削为太上皇,在中国的历史上就这个时期是有2个皇帝,你说这期间的大臣多郁闷,两个皇帝耶

,两个精神依附对象呀。

  这个场景放到我们设计模式中就是叫有上限的多例模式(没上限的多例模式太容易了,和你直接new一个对象没啥差别,不讨论)怎么实现呢,看我出 招,先看类图:

然后看程序,先把两个皇帝定义出来:

  1. package com.iadmob.multition;
  2.  
  3. import java.util.ArrayList;
  4. import java.util.Random;
  5.  
  6. /**
  7. * @author http://www.cnblogs.com/initial-road/
  8. * 中国的历史上一般都是一个朝代一个皇帝,有两个皇帝的话,必然要PK出一个湟谷地出来。
  9. * 问题出来了:如果真在一个时间,中国出现了两个皇帝怎么办?比如明朝土木堡之变后,
  10. * 明英宗被俘虏,明景帝即位,但是明景帝当上皇帝后乐疯了,竟然忘记把他老哥明英宗削为太上皇,
  11. * 也就是在这一个多月的时间内,中国竟然有两个皇帝!
  12. */
  13. public class Emperor {
  14. private static int maxNumOfEmperor = 2; //最多只能有两个皇帝
  15. private static ArrayList<String> emperorInfoList = new ArrayList<String>(maxNumOfEmperor); //皇帝叫什么名字
  16. private static ArrayList<Emperor> emperorList = new ArrayList<Emperor>(maxNumOfEmperor); //装皇帝的列表
  17. private static int countNumOfEmperor = 0; //正在被人尊称的是那个皇帝
  18.  
  19. //就这么多皇帝了,不允许在推举一个皇帝(new 一个皇帝)
  20. private Emperor(){
  21. //世俗和道德约束你,目的就是不让你产生第二个皇帝
  22. }
  23.  
  24. private Emperor(String info){
  25. emperorInfoList.add(info);
  26. }
  27.  
  28. //先把2个皇帝产生出来
  29. static{
  30. //把所有的皇帝都产生出来
  31. for(int i=0;i<maxNumOfEmperor;i++){
  32. emperorList.add(new Emperor("皇"+(i+1)+"帝"));
  33. }
  34. }
  35.  
  36. public static Emperor getInstance(){
  37. Random random = new Random();
  38. countNumOfEmperor = random.nextInt(maxNumOfEmperor); //随机拉去一个皇帝,只要是个精神领袖就成
  39. return (Emperor) emperorList.get(countNumOfEmperor);
  40. }
  41.  
  42. //皇帝叫什么名字呀
  43. public static void emperorInfo(){
  44. System.out.println(emperorInfoList.get(countNumOfEmperor));
  45. }
  46. }

那大臣是比较悲惨了,两个皇帝呀,两个老子呀,怎么拜呀,不管了,只要是个皇帝就成:

  1. package com.iadmob.multition;
  2.  
  3. /**
  4. * @author http://www.cnblogs.com/initial-road/
  5. * 大臣们悲惨了,一个皇帝都伺候不过来了,现在还来了2个皇帝
  6. * TMD,不管了,找到个皇帝,磕头,请安就成了!
  7. */
  8. public class Minister {
  9.  
  10. public static void main(String[] args){
  11. int ministerNum = 10; //10个大臣
  12. for(int i=0;i<ministerNum;i++){
  13. Emperor emperor = Emperor.getInstance();
  14. System.out.print("第"+(i+1)+"个大臣参拜的是:");
  15. emperor.emperorInfo();
  16. }
  17. }
  18.  
  19. }

那各位看官就可能会不屑了:有的大臣可是有骨气,只拜一个真神,你怎么处理?getInstance(param)就可以处理了!

24种设计模式--多例模式【Multition Pattern】的更多相关文章

  1. 二十四种设计模式:命令模式(Command Pattern)

    命令模式(Command Pattern) 介绍将一个请求封装为一个对象,从而使你可用不同的请求对客户进行参数化:对请求排队或记录请求日志,以及支持可取消的操作. 示例有一个Message实体类,某个 ...

  2. 二十四种设计模式:解释器模式(Interpreter Pattern)

    解释器模式(Interpreter Pattern) 介绍给定一个语言, 定义它的文法的一种表示,并定义一个解释器,该解释器使用该表示来解释语言中的句子. 示例有一个Message实体类,某个类对它的 ...

  3. 二十四种设计模式:迭代器模式(Iterator Pattern)

    迭代器模式(Iterator Pattern) 介绍提供一种方法顺序访问一个聚合对象中各个元素,而又不需暴露该对象的内部表示. 示例有一个Message实体类,某聚合对象内的各个元素均为该实体对象,现 ...

  4. 二十四种设计模式:代理模式(Proxy Pattern)

    代理模式(Proxy Pattern) 介绍为其他对象提供一个代理以控制对这个对象的访问. 示例有一个Message实体类,某对象对它的操作有Insert()和Get()方法,用一个代理来控制对这个对 ...

  5. 二十四种设计模式:策略模式(Strategy Pattern)

    策略模式(Strategy Pattern) 介绍定义一系列的算法,把它们一个个封装起来,并且使它们可相互替换.本模式使得算法的变化可独立于使用它的客户. 示例有一个Message实体类,对它的操作有 ...

  6. 二十四种设计模式:组合模式(Composite Pattern)

    组合模式(Composite Pattern) 介绍将对象组合成树形结构以表示"部分-整体"的层次结构.它使得客户对单个对象和复合对象的使用具有一致性.示例有一个Message实体 ...

  7. 二十四种设计模式:状态模式(State Pattern)

    状态模式(State Pattern) 介绍允许一个对象在其内部状态改变时改变它的行为.对象看起来似乎修改了它所属的类. 示例有一个Message实体类,对它的操作有Insert()和Get()方法, ...

  8. 二十四种设计模式:原型模式(Prototype Pattern)

    原型模式(Prototype Pattern) 介绍用原型实例指定创建对象的种类,并且通过拷贝这个原型来创建新的对象.示例有一个Message实体类,现在要克隆它. MessageModel usin ...

  9. 二十四种设计模式:外观模式(Facade Pattern)

    外观模式(Facade Pattern) 介绍为子系统中的一组接口提供一个一致的界面,Facade模式定义了一个高层接口,这个接口使得这一子系统更加容易使用.示例有一个Message实体类,某对象对它 ...

随机推荐

  1. 【转】在Ubuntu下编译Android源码并运行Emulator

    原文网址:http://www.mcuos.com/thread-4553-1-1.html 建立编译环境 1.在VirtualBox上安装Ubuntu 2.安装JDK   $ sudo apt-ge ...

  2. [回顾]SVE回顾

    SVE回顾 写完后的自评:书写太过凌乱,基本无法阅读. 前几日,SVE通过了TR5,虽说是一个小得不能再小的项目,即使到最后也存在一些未能解决的问题,但在用户的通融下还是在超期一段时间后写下了一个暂时 ...

  3. ubuntu14.04安装百度云Bcloud

    git地址:https://github.com/LiuLang/bcloud-packages sudo apt-get install python3-setuptools md5sum bclo ...

  4. Sicily1059-Exocenter of a Trian

    代码地址: https://github.com/laiy/Datastructure-Algorithm/blob/master/sicily/1059.c 1059. Exocenter of a ...

  5. AC自动机——多模式串匹配的算法思想

    标准KMP算法用于单一模式串的匹配,即在母串中寻求一个模式串的匹配,但是现在又存在这样的一个问题,如果同时给出多个模式串,要求找到这一系列模式串在母串存在的匹配个数,我们应该如何处理呢? 基于KMP算 ...

  6. C/C++基础(二)

    (1)运算符优先级 #include <cstdio> using namespace std; int main() {    unsigned char a = 0xA5;    un ...

  7. JUnit-4.11使用报java.lang.NoClassDefFoundError: org/hamcrest/SelfDescribing错误

    今天尝试使用JUnit,下载了最新的JUnit版本,是4.11,结果尝试使用发现总是报java.lang.NoClassDefFoundError: org/hamcrest/SelfDescribi ...

  8. android 回车键事件编程

    实现android按下回车键便隐藏输入键盘,有两种方法: 1.)如果布局是多个EditText,为每个EditText控件设置android:singleLine=”true”,弹出的软盘输入法中回车 ...

  9. 关于verilog中if与case语句不完整产生锁存器的问题 分类: FPGA 2014-11-08 17:39 260人阅读 评论(0) 收藏

    在很多地方都能看到,verilog中if与case语句必须完整,即if要加上else,case后要加上default语句,以防止锁存器的发生,接下来就来说说其中原因. 一,什么是锁存器?锁存器与触发器 ...

  10. Mate8的麒麟950怎么样? 4个问题待解决

    今天下午,华为在上海发布了传闻已久的旗舰智能手机Mate 8.这款手机可以算是国产手机的佼佼者,不光在外观.功能等常规元素上达到旗舰级别,更有特色的是它采用了华为自行研发的手机SOC芯片麒麟950.目 ...