1.简单来说__new__方法和__init__方法都是类中的内置方法;这两个方法再实例化对象的时候会被自动调用;
2.__new__方法的调用在 __init__方法之前;
3.__new__方法中有个参数:cls ; __init__方法中有个参数是self
4.__new__方法的作用是:(1)为实例化对象分配一个空间(2)返回这个对象的引用
5.__init__方法的作用是对这个实例化对象再次加工;self指的就是这个实例化对象
看代码:
class MusicPlayer(object): #创建一个音乐播放器 def __new__(cls, *args, **kwargs): print("创建对象,分配空间") # 1. 创建对象时,new方法会被自动调 instance = super().__new__(cls) # 2. 为对象分配空间 return instance # 3. 返回对象的引用,必须的有这个返回,不然self找不到对象 def __init__(self,name): #初始化方法;对这个实例化对象再次加工
self.name = name print("播放器初始化") # 创建播放器对象 player = MusicPlayer("小米") print(player)
做个不是很恰当的比喻(暂时想到的这个);类就好比一张大楼的图纸;我们要按着这个图纸去建大楼;而__new__方法就好比建造这个大楼的地址,你是要在北京盖楼还是上海盖楼,必须有个明确的地址,而__init__方法就好比;有了图纸和地方就开始建楼吧。
二通过__new__方法实现单例模式
首先要明白什么是单例模式:简单理解就是一个类只能创建一个实例对象(还用上面这个比喻,就是说我们这个开发商比较小,只能拿到一块地皮;当我们第一次用这块地盖了楼,又想盖第二栋没有地皮怎么办啊,简单把把上次盖好的拆掉就又有地方了啊)
看代码:
class MusicPlayer(object): def __new__(cls, *args, **kwargs): # 1. 创建对象时,new方法会被自动调用 print("创建对象,分配空间") # 2. 为对象分配空间 instance = super().__new__(cls) # 3. 返回对象的引用 return instance def __init__(self): print("播放器初始化") # 创建播放器对象 player1 = MusicPlayer() player2 = MusicPlayer() print(id(player1)) print(id(player2))
打印结果:这是一个正常的实例化对象;创建了两个对象;这两个对象的ID是不一样的
创建对象,分配空间 播放器初始化 创建对象,分配空间 播放器初始化 2525789450312 2525789421464
单例模式:
class MusicPlayer(object): instance = None #定义一个类属性为None def __new__(cls, *args, **kwargs): # 1. 创建对象时,new方法会被自动调用 print("创建对象,分配空间") if cls.instance is None: #如果这个类属性为None就为这个对象分配一个空间 # 2. 为对象分配空间 cls.instance = super().__new__(cls) # 3. 返回对象的引用 return cls.instance #否则返回上一个对象空间 def __init__(self): print("播放器初始化") # 创建播放器对象 player1 = MusicPlayer() player2 = MusicPlayer() print(id(player1)) print(id(player2))
结果:
创建对象,分配空间 播放器初始化 创建对象,分配空间 播放器初始化 2300636655688 2300636655688
那么创建的两个实例化对象的id就一样了