python中的__new__方法与单例模式

本文将简单地介绍__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

这便是简单地单例模式,写的比较笼统

你可能感兴趣的:(python3)