首页 > 代码库 > 多例模式【Multition Pattern】

多例模式【Multition Pattern】

  这种情况有没有?有!大点声,有没有?有,是,确实有,就出现在明朝,那三国期间的算不算,不算,各自称帝,各有各的地盘,国号不同。大家还
记得那首诗《石灰吟》吗?作者是谁?于谦,他是被谁杀死的?明英宗朱祁镇,对,就是那个在土木堡之变中被瓦刺俘虏的皇帝,被俘虏后,他弟弟朱祁钰当上
了皇帝,就是明景帝,估计当上皇帝后乐疯了,忘记把老哥朱祁镇削为太上皇,在中国的历史上就这个时期是有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)就可以处理了!

多例模式【Multition Pattern】