python中的__new__方法
1.创建类时先执行type的__init__方法,
2.当一个类实例化时(创建一个对象)执行type的__call__方法,__call__方法的返回值就是实例化的对象
__call__内部调用
-类.__new__方法,创建一个对象
-类.__init__方法,初始化对象
实例化对象是谁取决于__new__方法,__new__返回什么就是什么
__new__() 方法的特性:
- __new__() 方法是在类准备将自身实例化时调用。
- __new__() 方法始终都是类的静态方法,即使没有被加上静态方法装饰
class Foo(object):
pass
obj=Foo() #默认是调用该类的直接父类的__new__()方法来构造该类的实例
print(obj) #打印结果:<__main__.Foo object at 0x000002636FEAA208>
事实上如果(新式)类中没有重写__new__()方法,即在定义新式类时没有重新定义__new__()时,Python默认是调用该类的直接父类的__new__()方法来构造该类的实例,
如果该类的父类也没有重写__new__(),那么将一直按此规矩追溯至object的__new__()方法,因为object是所有新式类的基类。
class F1(object):
#重写__new__方法,返回这个重写的__new__方法
def __new__(cls, *args, **kwargs):
return 123
obj=F1() #实例化对象是谁取决于__new__方法,__new__返回什么就是什么
print(obj,type(obj)) #打印结果:123 <class 'int'>
class F2(object):
pass
class F3(object):
def __new__(cls, *args, **kwargs):
return F2()
obj=F3() #实例化对象是谁取决于__new__方法,__new__返回什么就是什么
print(obj) #<__main__.F2 object at 0x00000210119BA4A8>
如果要得到当前类的实例,应当在当前类中的 __new__() 方法语句中调用当前类的父类的 __new__() 方法。
例如,如果当前类是直接继承自 object,那当前类的 __new__() 方法返回的对象应该为:
def __new__(cls, *args, **kwargs):
...
return object.__new__(cls)
__new__至少要有一个参数cls,代表要实例化的类,此参数在实例化时由Python解释器自动提供
__new__必须要有返回值,返回实例化出来的实例,这点在自己实现__new__时要特别注意,可以return父类__new__出来的实例,或者直接是object的__new__出来的实例
__init__有一个参数self,就是这个__new__返回的实例,__init__在__new__的基础上可以完成一些其它初始化的动作,__init__不需要返回值
有了__call__就可以把对象当作函数一样的调用了。也就是说__call__()的作用是使实例能够像函数一样被调用,同时不影响实例本身的生命周期(__call__()不影响一个实例的构造和析构)。但是__call__可以用来改变实例的内部成员的值。
#新建一个类
class Student():
#进行初始化
def __init__(self, name, age, ):
self.name = name
self.age = age
def __call__(self, age):
self.age = age
def __str__(self):
return f'{self.name}的年龄是{self.age}'
#实例化一个学生出来
student1 = Student('bill', 12)print(student1)
#现在进行年龄的更改,就可以象调用方法一样的调用了。
student1(34)print(student1) #=> bill的年龄是34
#一个小的总结:
__new__: 对象的创建,是一个静态方法,第一个参数是cls。有返回值,返回值为对象本身,代码如下
class MusicPlayer(object): # 为对象分配内存空间 def __new__(cls, *args, **kwargs): # 1. 创建对象时,new方法会被自动调用 print("创建对象,分配内存空间") # 2. 为对象分配空间 instance = super().__new__(cls) # 3. 返回对象的引用 return instance # 对象初始化,定义实例属性 def __init__(self): print("播放器初始化") # 创建播放器对象 player = MusicPlayer() print(player)
__init__ : 对象的初始化, 是一个实例方法,第一个参数是self,初始化的时候就具有的属性,这个属性可以设默认值。,无返回值
__call__ : 对象可被掉用,注意不是类,是对象。对象可以被调用,否则是不可以的,这里面的不能设默认值。
————————————————
版权声明:本文为CSDN博主「军械士官长」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/junxieshiguan/article/details/82502437
————————————————
版权声明:本文为CSDN博主「军械士官长」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/junxieshiguan/article/details/82502437