码迷,mamicode.com
首页 > 其他好文 > 详细

多例模式【Multition Pattern】

时间:2014-10-06 00:02:09      阅读:240      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   color   io   ar   java   for   sp   

  这种情况有没有?有!大点声,有没有?有,是,确实有,就出现在明朝,那三国期间的算不算,不算,各自称帝,各有各的地盘,国号不同。大家还
记得那首诗《石灰吟》吗?作者是谁?于谦,他是被谁杀死的?明英宗朱祁镇,对,就是那个在土木堡之变中被瓦刺俘虏的皇帝,被俘虏后,他弟弟朱祁钰当上
了皇帝,就是明景帝,估计当上皇帝后乐疯了,忘记把老哥朱祁镇削为太上皇,在中国的历史上就这个时期是有2个皇帝,你说这期间的大臣多郁闷,两个皇帝耶
,两个精神依附对象呀。

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

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

 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】

标签:style   blog   http   color   io   ar   java   for   sp   

原文地址:http://www.cnblogs.com/initial-road/p/multition_pattern.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!