设计模式----多例模式(Multition)

Emperor.java 代码如下:
package com.designPattern.multition;

import java.util.ArrayList;
import java.util.Random;

/**
 * 两个皇帝的故事
 * @author yangjianzhou
 *
 */
public class Emperor {
	private static int maxNumOfEmperor = 2;
	private static ArrayList<String> emperorInfoList = new ArrayList<String>(maxNumOfEmperor);
	private static ArrayList<Emperor> emperorList = new ArrayList<Emperor>(maxNumOfEmperor);
	private static int countNumOfEmperor = 0;
	
	/**
	 * 先产生两个皇帝出来
	 */
	static{
		for(int i=0;i<maxNumOfEmperor;i++){
			emperorList.add(new Emperor("皇"+(i+1)+"帝"));
		}
	}
	
	/**
	 * 不允许在产生皇帝
	 */
	private Emperor(){
		
	}
	
	private Emperor(String info){
		emperorInfoList.add(info);
	}
	
	public static Emperor getInstance(){
		Random random = new Random();
		countNumOfEmperor = random.nextInt(maxNumOfEmperor);
		return emperorList.get(countNumOfEmperor);
	}
	
	public static void emperorInfo(){
		System.out.println(emperorInfoList.get(countNumOfEmperor));
	}

}



Minister.java代码如下:
package com.designPattern.multition;

public class Minister {
	
	public static void main(String[] args) {
		
		int ministerNum = 10;
		
		for(int i=0;i<ministerNum;i++){
			Emperor emperor = Emperor.getInstance();
			System.out.print("第"+(i+1)+"个大臣参拜的皇帝是:");
			emperor.emperorInfo();
		}
	}

}



运行结果如下:
第1个大臣参拜的皇帝是:皇2帝
第2个大臣参拜的皇帝是:皇1帝
第3个大臣参拜的皇帝是:皇1帝
第4个大臣参拜的皇帝是:皇1帝
第5个大臣参拜的皇帝是:皇2帝
第6个大臣参拜的皇帝是:皇1帝
第7个大臣参拜的皇帝是:皇2帝
第8个大臣参拜的皇帝是:皇2帝
第9个大臣参拜的皇帝是:皇1帝
第10个大臣参拜的皇帝是:皇2帝

你可能感兴趣的:(设计模式)