本文将简单地介绍__new__
方法的使用,然后引出单例模式。
__new__
方法就是初始化实例对象的,假如和__init__
一起存在的话,会先执行___new__
方法,
简单地看个例子:
class A:
def __init__(self, name):
self.name = name
def __new__(cls, *args, **kw):
print('bbb')
return object.__new__(cls)
a = A('张三')
print(a.name)
# 结果
# bbb
# 张三
什么时候使用__new__
方法呢?参考链接
单例模式
什么是单例模式:对象只会被实例化一次,从第二次开始其实就是用的第一次实例化的对象,相当于全局。可根据地址判断看一下
class A:
def __init__(self, name):
self.name = name
# 实例化三个对象
a = A('张三')
b = A('李四')
c = A('王五')
# 打印结果地址是不同的,既实例化了三个对象
print(a) # <__main__.A object at 0x029CE5B0>
print(b) # <__main__.A object at 0x00A009B0>
print(c) # <__main__.A object at 0x00A00C10>
# 将 a 的名字改成阿黄,查看一下 b 和 c 的名字
a.name = '阿黄'
print(a.name) # 阿黄
print(b.name) # 李四
print(c.name) # 王五
由此可见,实例与实例之间都是独立的。
而单例模式则是,所有的实例化对象都公用一个内存地址,当一个对象改变某些属性或方法时,其他的对象也会跟着改变。
先实现一下单例模式:
class A:
__isinstance = False # 设置一个私有变量,默认没有被实例化
def __init__(self, name):
self.name = name
def __new__(cls, *args, **kwargs):
if cls.__isinstance: # 如果被实例化了
return cls.__isinstance # 返回实例化对象
cls.__isinstance = object.__new__(cls) # 否则实例化
return cls.__isinstance # 返回实例化的对象
# 实例化三个对象
a = A('张三')
b = A('李四')
c = A('王五')
# 打印三个对象的地址,结果都是一个地址
print(a) # <__main__.A object at 0x00EFECF0>
print(b) # <__main__.A object at 0x00EFECF0>
print(c) # <__main__.A object at 0x00EFECF0>
# 改变 a 对象的 name 属性,查看 b , c 的 name 属性
a.name = '阿黄'
print(a.name) # 阿黄
print(b.name) # 阿黄
print(c.name) # 阿黄
# 给 b 添加一个 age 属性,查看 a, c 的 age 属性(有没有,是什么)
b.age = 15
print(a.age) # 15
print(b.age) # 15
print(c.age) # 15
这便是简单地单例模式,写的比较笼统