zoukankan      html  css  js  c++  java
  • JAVA设计模式——第 4 章 多例模式【Multition Pattern】(转)

        一个国家有多个皇帝这种情况有没有?还确实有,就出现在明朝,那三国期间的算不算,不算!因为各自称帝,各有各的地盘,国号不同。大家还记得那首诗《石灰吟》吗?作者是谁?于谦,他是被谁杀死的?明英宗朱祁镇,对,就是那个在土木堡之变中被瓦刺俘虏的皇帝,被俘虏后,他弟弟朱祁钰当上了皇帝,就是明景帝,估计当上皇帝后乐疯了,忘记把老哥朱祁镇削为太上皇了,于是在中国的历史上就这个时期是有2个皇帝。这期间的大臣很郁闷,两个皇帝耶,两个精神依附对象。这个场景放到我们设计模式中就是叫有上限的多例模式(没上限的多例模式太容易了,和你直接new 一个对象没啥差别,不讨论)怎么实现呢,看我出招,先看类图:

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

    package com.cbf4life.singleton2;
    
    import java.util.ArrayList;
    import java.util.Random;
    
    /**
     * @author cbf4Life cbf4life@126.com I'm glad to share my knowledge with you
     *         all. 中国的历史上一般都是一个朝代一个皇帝,有两个皇帝的话,必然要PK出一个皇帝出来。
     *         问题出来了:如果真在一个时间,中国出现了两个皇帝怎么办?比如明朝土木堡之变后,
     *         明英宗被俘虏,明景帝即位,但是明景帝当上皇帝后乐疯了,竟然忘记把他老哥明英宗削为太上皇, 也就是在这一个多月的时间内,中国竟然有两个皇帝!
     * 
     */
    @SuppressWarnings("all")
    public class Emperor {
        private static int maxNumOfEmperor = 2; // 最多只能有连个皇帝
        private static ArrayList emperorInfoList = new ArrayList(maxNumOfEmperor); // 皇帝叫什么名字
        private static ArrayList emperorList = new ArrayList(maxNumOfEmperor); // 装皇帝的列表;
        private static int countNumOfEmperor = 0; // 正在被人尊称的是那个皇帝
        // 先把2个皇帝产生出来
        static {
            // 把所有的皇帝都产生出来
            for (int i = 0; i < maxNumOfEmperor; i++) {
                emperorList.add(new Emperor("皇" + (i + 1) + "帝"));
            }
        }
    
        // 就这么多皇帝了,不允许再推举一个皇帝(new 一个皇帝)
        private Emperor() {
            // 世俗和道德约束你,目的就是不让你产生第二个皇帝
        }
    
        private Emperor(String info) {
            emperorInfoList.add(info);
        }
    
        public static Emperor getInstance() {
            Random random = new Random();
            countNumOfEmperor = random.nextInt(maxNumOfEmperor); // 随机拉出一个皇帝,只要是个精神领袖就成
            return (Emperor) emperorList.get(countNumOfEmperor);
        }
    
        // 皇帝叫什么名字呀
        public static void emperorInfo() {
            System.out.println(emperorInfoList.get(countNumOfEmperor));
        }
    }

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

    package com.cbf4life.singleton2;
    
    /**
     * @author cbf4Life cbf4life@126.com I'm glad to share my knowledge with you
     *         all. 大臣们悲惨了,一个皇帝都伺候不过来了,现在还来了两个个皇帝 TND,不管了,找到个皇帝,磕头,请按就成了!
     */
    @SuppressWarnings("all")
    public class Minister {
        /**
         * @param args
         */
        public static void main(String[] args) {
            int ministerNum = 10; // 10个大臣
            for (int i = 0; i < ministerNum; i++) {
                Emperor emperor = Emperor.getInstance();
                System.out.print("第" + (i + 1) + "个大臣参拜的是:");
                emperor.emperorInfo();
            }
        }
    }

        那各位看官就可能会不屑了:有的大臣可是有骨气,只拜一个真神,你怎么处理?这个问题太简单,懒的详细回答你,getInstance(param)是不是就解决了这个问题?!自己思考,太Easy 了。

  • 相关阅读:
    性能测试的感悟
    Web性能测试问题,mysql分析之一
    LoadRunner使用代理远程执行提示找不到“pre_cci.c”文件
    yii widget验证码不实用form验证的方法
    mysql 1449 : The user specified as a definer ('root'@'%') does not exist 解决方法
    (亲测)nginx解决thinkphp中pathinfo的问题
    一个超好用的php header下载函数
    编程中的一些概念,KISS、DRY、MVC、OOP、REST
    8个开发必备的PHP功能(转)
    关于按钮在短时间内多次点击的问题.
  • 原文地址:https://www.cnblogs.com/liqiu/p/3349164.html
Copyright © 2011-2022 走看看