多例模式

  多例模式实际上就是单例模式的推广,多例模式又划分为有上限多例模式无上限多例模式两种,有上限多例模式中的多例类的实例是有上限的,当这个多例类中的上限数值上等于 1 时,此时,多例类退化回到了单例类;而对于无上限多例模式中的多例类,它的上限是没有限制的,也就是说它的上限数值是不确定的,这个多例类并不一定能够退化成单例类;

单例模式与多例模式一般性结构:

 

多例模式特点:

  1.  多例类可以有多个实例
  2. 多例类必须自己创建自己的实例,并管理自己的实例,和向外界提供自己的实例

  多例类的一个实例,比如:一副麻将都需要有两颗骰子,在没有特别意外发生的情况下,这副麻将打多少圈用的都将是这两颗骰子,两颗骰子代表的是不同的两个状态,

这里可以将骰子设计成多例类,如图:

 

  多例类:Dice.java

package pattern.multion;
import java.util.Random;
/**
 * -----------------------------------------
 * @描述  骰子有上限多例类
 * -----------------------------------------
 */
public class Dice {
    public  static final int  INSTANCE1 = 0;
    public  static final int  INSTANCE2 = 1;
    private static final Dice DICE_INSTANCE1 = new Dice(); //饿汉式
    private static final Dice DICE_INSTANCE2 = new Dice(); //饿汉式
    //私有化构造子,阻止外部直接实例化对象
    private Dice(){
    }
    /**
     * 获取多例类的实例
     */
    public static Dice getInstance(int which){
        switch(which){
            case INSTANCE1 :
                return DICE_INSTANCE1;
            case INSTANCE2 :
                return DICE_INSTANCE2;
            default :
                try {
                    throw new Exception("找不到与参数 " + which + " 相匹配的实例!");
                } catch (Exception e) {e.printStackTrace();}
        }
        return null;
    } 

  /**
    * 此方法是线程安全的,调用该方法来掷骰子
    */
    public synchronized int roll(){   
        try {
            Random ran = new Random(System.currentTimeMillis());
            int rollValue = ran.nextInt();
            rollValue %= 6;
            Thread.sleep(6);
            return rollValue > 0 ? ++rollValue : --rollValue * -1;
        } catch (Exception e) {e.printStackTrace();}
        return 1;
    }
}
View Code

客户端测试类:Mahjong.java

package pattern.multion;
/**
 * @描述  客户端测试类
 */

public class Mahjong {
    private static Dice dice1 = Dice.getInstance(Dice.INSTANCE1),
                                          dice2 = Dice.getInstance(Dice.INSTANCE2);
    public static void main(String[] args){
        int value1 = dice1.roll();
        int value2 = dice2.roll();
        System.out.println(value1);
        System.out.println(value2);
    }
}
View Code
在Python中,可以使用元类(metaclass)来实现多例模式。一个简单的示例代码如下: ```python class MultiInstance(type): instance = {} def __call__(cls, *args, **kwargs): key = (cls.__name__, args, tuple(kwargs.items())) if key not in cls.instance: cls.instance[key = super().__call__(*args, **kwargs) return cls.instance[key] class API(metaclass=MultiInstance): # 实现API类的方法和属性 pass ``` 在这个示例代码中,我们定义了一个名为MultiInstance的元类,它的作用是创建一个字典来存储不同实例的引用。在元类的`__call__`方法中,我们使用传入的类名、参数和关键字参数来作为key,检查是否已经存在该实例,如果不存在则创建一个新的实例并存储在字典中,最后返回该实例。 通过将API类的metaclass设置为MultiInstance,我们就可以在创建API类的实例时实现多例模式。每次创建API类的实例时,都会检查是否已经存在相同参数的实例,如果存在则返回已有实例,如果不存在则创建新的实例。 除了使用元类,还可以使用装饰器来实现单例模式。一个简单的示例代码如下: ```python def singleton(cls): instance = {} def wrapper(*args, **kwargs): if cls not in instance: instance = cls(*args, **kwargs) return instance<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [python接口自动化中单例模式多例模式](https://blog.csdn.net/m0_53396342/article/details/130180677)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [python 锁的使用 python锁的使用例程python2可以直接运行,提供示例程序,供学习参考](https://download.csdn.net/download/li171049/88228463)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值