注意点
特殊方法名 | 默认的参数 | 功能描述 |
__init__() | self | |
__str__() | self | |
__del__() | self | |
__new__() | cls | |
单例模式
1. 单例是什么
举个常见的单例模式例子,我们日常使用的电脑上都有一个回收站,在整个操作系统中,回收站只能有一个实例,整个系统都使用这个唯一的实例,而且回收站自行提供自己的实例。因此回收站是单例模式的应用。
class User(object):
__instance=None
def __init__(self,name):
self.name=name
@classmethod
def get_instance(cls,name):
if not cls.__instance:
#如果__instance 为None
cls.__instance=User(name)
return cls.__instance
#u1 = User('zs')
#u2 = User('ls')
u1 = User.get_instance('zs')
u2 = User.get_instance('ls')
#u3=User('ww')
print(u1==u2)
#==判断表达式如果返回True,这两个对象是一个对象,并且内存地址相同
print('u1对象的内存地址:%s,u2对象的内存地址:%s'%(id(u1),id(u2)))
确保某一个类只有一个实例,而且自行实例化并向整个系统提供这个实例,这个类称为单例类,单例模式是一种对象创建型模式。
2. 创建单例-保证只有1个对象
# 实例化一个单例classSingleton(object):
__instance = Nonedef__new__(cls, age, name):
#如果类数字能够__instance没有或者没有赋值#那么就创建一个对象,并且赋值为这个对象的引用,保证下次调用这个方法时#能够知道之前已经创建过对象了,这样就保证了只有1个对象ifnot
cls.__instance:
cls.__instance = object.__new__(cls)
return cls.__instance
a = Singleton(18, 'bin')
b = Singleton(8, 'bin')
print(id(a))
print(id(b))
a.age = 19#给a指向的对象添加一个属性
print(b.age)#获取b指向的对象的age属性
运行结果:
class User(object):
__instance=None
def __init__(self,name):
self.name=name
def __new__(cls,name):
if not cls.__instance:#保证 object.__new__()方法只会调用一次
cls.__instance=object.__new__(cls)
return cls.__instance
u1 = User('zs')
u2 = User('ls')
print(u1.name,u2.name)
print(u1==u2)
#==判断表达式如果返回True,这两个对象是一个对象,并且内存地址相同
print('u1对象的内存地址:%s,u2对象的内存地址:%s'%(id(u1),id(u2)))
In [12]: classSingleton(object):
...: __instance = None
...:
...: def__new__(cls, age, name):
...: ifnot cls.__instance:
...: cls.__instance = object.__new__(cls)
...: return cls.__instance
...:
...: a = Singleton(18, 'bin')
...: b = Singleton(8, 'bin')
...:
...: print(id(a))
...: print(id(b))
...:
...: a.age = 19
...: print(b.age)
...:
4391023224439102322419
3. 创建单例时,只执行1次__init__方法
# 实例化一个单例classSingleton(object):
__instance = None
__first_init = False
def__new__(cls, age, name):
if not cls.__instance:
cls.__instance = object.__new__(cls)
return cls.__instance
def__init__(self, age, name):
if not self.__first_init:
self.age = age
self.name = name
Singleton.__first_init = Truea = Singleton(18, 'bin')
b = Singleton(8, 'bin')
print(id(a))
print(id(b))
print(a.age)
print(b.age)
a.age = 19print(b.age)