单例模式
现在有这么个需求:类每次实例化时,都会去创建一个新的类对象。如果要求不管实例化几次,都只会创建一次新的类对象,该如何实现?
答:单例模式就可以实现这个需求,好处就是可以降低内存占用率,并提高性能。可以用在一些经常被调用到的封装类,比如说读取配置文件类。
类每次实例化时,都会创建一个新的对象:
class Hero4(object):
pass
h1 = Hero4()
print(id(h1)) # 31340024
h2 = Hero4()
print(id(h2)) # 31377560
单例模式的表现
单例模式的实现思路
单例模式的代码实现【面试常问】
实现单例模式(最简单的单例模式)
class Hero(object):
“”“单例模式类”""
__flag = False # 判断类是否创建过对象
__cls = None # 用于存储创建的对象
def __new__(cls, *args, **kwargs):
if not cls.__flag: # 如果没有创建过对象
cls.__cls = super().__new__(cls) # 父类方法创建个对象,并存储起来
cls.__flag = True # 修改判断属性
return cls.__cls # 返回创建好的对象
else: # 如果已经创建过对象
return cls.__cls # 直接返回第一次创建好的对象
两次的类对象id都是一样的,证明单例模式实现成功
h1 = Hero()
h2 = Hero()
print(id(h1), id(h2)) # 34719112 34719112
简化单例模式,直接使用存储类的属性来进行判断是否创建过对象
class Hero(object):
__cls = None # 存储类对象的属性,安全起见,用私有属性
print(‘类这里的内容,是执行当前py文件时就执行了。所以这里的属性值不受类的调用影响’)
def __new__(cls, *args, **kwargs):
# None的布尔值是False
if not cls.__cls: # 如果该属性为None,则说明没创建过对象
cls.__cls = super().__new__(cls)
return cls.__cls
else:
return cls.__cls
h1 = Hero()
h2 = Hero()
print(id(h1), id(h2)) # 34981256 34981256