python_进阶_17


单例

  • 单例设计模式:
    • 目的: 让创建的对象,在系统中 只有 唯一的一个实例
    • 每一次执行 类名()返回的对象, 内存地址是相同的

new 方法

  • 重写new方法一定要return.super().__new__(cls)
  • 否则python的解释器得不到分配了空间的对象引用,就不会调用对象的初始化方法
  • 注意: __new__是一个静态方法,在调用时需要主动传递cls参数
class MusicPlayer(object):
    def __new__(cls, *args, **kwargs):
        # 1. 创建对象时,new方法会被自动调用
        print("创建对象,分配空间")
        # 2. 为对象分配空间
        instance = super().__new__(cls)
        # 3. 返回对象引用
        return instance
    def __init__(self):
        print("播放器初始化")

# 创建播放器对象
player = MusicPlayer()
print(player)

输出为

单例设计模式代码实现

class MusicPlayer(object):
    # 记录第一个被创建对象的引用
    # 赋值语句创建类属性
    instance = None

    def __new__(cls, *args, **kwargs):
        # 1. 判断类属性是否是空对象
        if cls.instance is None:
            # 2. 调用父类的方法,为第一个对象分配空间
            cls.instance = super().__new__(cls)
        # 3. 返回类属性保存的对象引用
        return cls.instance

# 创建多个对象
player1 = MusicPlayer()
print(player1)

player2 = MusicPlayer()
print(player2)

输出为

让单例初始化动作只执行一次

class MusicPlayer(object):
    # 记录第一个被创建对象的引用
    # 赋值语句创建类属性
    instance = None
    # 记录是否执行过初始化动作
    init_flag = False

    def __new__(cls, *args, **kwargs):
        # 1. 判断类属性是否是空对象
        if cls.instance is None:
            # 2. 调用父类的方法,为第一个对象分配空间
            cls.instance = super().__new__(cls)
        # 3. 返回类属性保存的对象引用
        return cls.instance

    def __init__(self):
        # 1. 判断是否执行过初始化动作
        if MusicPlayer.init_flag:
            return

        # 2. 如果没有执行过,再执行初始化动作
        print("初始化播放器")

        # 3. 修改类属性的标记
        MusicPlayer.init_flag = True

# 创建多个对象
player1 = MusicPlayer()
print(player1)

player2 = MusicPlayer()
print(player2)

输出为


文章作者: 张忠楠
版权声明: 本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 张忠楠 !
评论
 上一篇
python_进阶_18 python_进阶_18
异常 ==程序停止执行并且提示错误信息这个动作, 我们通常称之为: 抛出异常== 简单的错误捕获try: # 尝试执行的代码 # 不能确定正确执行的代码 num = int(input("请输入一个整数:")) e
2020-04-29
下一篇 
python_进阶_16 python_进阶_16
方法综合演练 需求 设计一个game类 属性: 定义一个类属性top_score记录游戏的历史最高分 定义一个实例属性player_name记录当前游戏的玩家姓名 方法: 静态方法show_help显示游戏帮助信息 类方法
2020-04-29
  目录