1. 什么是设计模式
设计模式是前人工作的总结和提炼,通常,被人们广泛流传的设计模式都是针对某一特定问题的成熟解决方案。
使用设计模式是为了可重用代码,让代码更容易被他人理解,保证代码可靠性。
2. 什么是单例设计模式
目的:让类创建对象,在系统中只有唯一的一个实例(对象)
每一次执行类名()返回的对象内存地址是相同的
2.1 __new__方法的概念
怎么保证这些对象只有一个?
__new__方法:
我们用类名()的方式创建对象的时候,python解释器会帮我们做两件事情,是哪两件事情呢?
1.为对象分配空间 2.对象初始化
使用类名()创建对象时,python的解释器首先会调用__new__方法为对象分配空间。__new__是一个由object基类提供的内置的静态方法,主要有两个作用:
- 在内存中为对象分配空间
- 返回对象的引用
python的解释器获得对象的引用后,将引用作为第一个参数,传递给__init__方法。
__ new__:负责给对象分配空间 __ init__(初始化方法)负责给对象初始化。
我们要重写new方法,使用类名()创建对象的时候,返回的都是同一个地址
2.2 __new__方法的代码
重写__new__方法的代码非常固定:
- 继承自父类方法
- 返回父类方法调用_new__方法的结果
重写__new__方法一定要return object.new(cls)
否则python的解释器得不到分配了空间的对象引用,就不会调用对象的初始化方法
3. 举例
3.1 分配不同的地址空间
class MusicPlayer(object):
instance = None
def __new__(cls, *args, **kwargs):
print('创建对象 分配空间')
# 1.创建对象的时候 __new__ 会被自动调用
instance = object.__new__(cls)
return instance
object.__new__(cls)
player1 = MusicPlayer()
print(player1)
player2 = MusicPlayer()
print(player2)
player3 = MusicPlayer()
print(player3)
输出结果:
创建对象 分配空间
<__main__.MusicPlayer object at 0x7f1a17320748>
创建对象 分配空间
<__main__.MusicPlayer object at 0x7f1a17320780>
创建对象 分配空间
<__main__.MusicPlayer object at 0x7f1a173207b8>
3.2 分配相同的地址空间
class MusicPlayer(object):
instance = None
def __new__(cls, *args, **kwargs):
print('创建对象 分配空间')
if cls.instance is None:
# 调用父类的方法 为第一个对象分配空间
cls.instance = object.__new__(cls)
return cls.instance
player1 = MusicPlayer()
print(player1)
player2 = MusicPlayer()
print(player2)
player3 = MusicPlayer()
print(player3)
输出结果:
创建对象 分配空间
<__main__.MusicPlayer object at 0x7f58369c3710>
创建对象 分配空间
<__main__.MusicPlayer object at 0x7f58369c3710>
创建对象 分配空间
<__main__.MusicPlayer object at 0x7f58369c3710>
可以看出,上述创建的对象内存地址一样,也就是说它们是同一个对象。
应用:手机听歌时一次只能播放一首歌