单例
- 单例设计模式:
- 目的: 让类创建的对象,在系统中 只有 唯一的一个实例
- 每一次执行
类名()
返回的对象, 内存地址是相同的
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)
输出为