class Singleton(object):
"""注释"""
__instanc=None
def __init__(self,name,age):
self.name=name
self.age=age
def __new__(cls, name, age):
"""创建一个单例的对象"""
#创建一个__instance用来存储第一次创建的对象引用
#如果是第一次创建,那么进行父类的调用来创建一个对象引用
#如果是第二次创建,那么就返回上一次创建好的对象引用给他
#所以他们公用的同一类的属性
if not cls.__instanc:
cls.__instanc=object.__new__(cls)
return cls.__instanc
a=Singleton("MoDou",19)
b=Singleton("lili",18)
print(id(a))
print(id(b))
b.addr="河南"
print(a.age)
print(a.name)
print(a.addr)
运行结果是
这时就能发现,两次建立的实例对象的id值是一样的,id值一样的话那么代表指向的是同一个对象。所以里面的数据都是公用的
这就是为什么明明在a实例对象中定义了name和age的引用值,但是确实b的值。因为python中一切都是赋值都是引用。
总结
__new__
至少要有一个参数cls,代表要实例化的类,此参数在实例化时由Python解释器自动提供
__new__
必须要有返回值,返回实例化出来的实例,这点在自己实现__new__
时要特别注意,可以return父类__new__
出来的实例,或者直接是object的__new__
出来的实例
__init__
有一个参数self,就是这个__new__
返回的实例,__init__
在__new__
的基础上可以完成一些其它初始化的动作,__init__
不需要返回值
我们可以将类比作制造商,__new__
方法就是前期的原材料购买环节,__init__
方法就是在有原材料的基础上,加工,初始化商品环节