1.魔法方法总是被双下划线保卫,例如__init__,魔法方法是面向对象的Python的一切,魔法方法的“魔力”体现在它们总能够在适当的时候被自动调用,比如
①__init__(self,[...]),举例:
>>> class Rectangle:
def __init__(self,x,y):
self.x = x
self.y = y
def getPeri(self):
return (self.x+self.y)*2
def getArea(self):
return self.x*self.y
>>> rect = Rectangle(3,4)
>>> rect.getPeri()
14
即在有需求的时候,改动构造函数__init__(self),比如上例需要传入参数。注意此处init是用来设置原始参数的,不要试图用其进行数据返回,举例:>>> class A:
def __init__(self):
return "A fo A—Cup"
>>> a=A()
Traceback (most recent call last):
File "<pyshell#22>", line 1, in <module>
a=A()
TypeError: __init__() should return None, not 'str';
②.__new__(cls[,...]):new方法是创建对象时调用,会返回当前对象的一个实例,因此需要一个实例化对象,重写这个方法一般是在继承一个不可变类型又需要修改的时候,举例:
>>> class CapStr(str):
def __new__(cls,string):
string = string.upper()
return str.__new__(cls,string)
>>> a=CapStr("i love you")
>>> a
'I LOVE YOU'
此处CapStr(str),是继承str类,是不可对其对象进行自身修改的,所以应该在__new__的时候把对象进行替换,然后再调用替换后的__new__;
③.__del__(self):如果说__init__和__new__方法是对象的构造器的话,那么__del__就是python提供的一个析构器,当对象要被销毁的时候会自动调用这个方法,当垃圾回收机制,举例:
>>> class C:
def __init__(self):
print("我是__init__方法,我被调用了。")
def __del__(self):
print("我是__del__方法,我被调用了。")
>>> c1=C()
我是__init__方法,我被调用了。
>>> c2 = c1
>>> c3 = c2
>>> del c3
>>> del c2
>>> del c1
我是__del__方法,我被调用了。
此例可以看出,当没有对象指向类的时候,类才会被当作垃圾被回收,因此需要将指向该类的对象都进行删除,才会触发这个方法,而不是说因为c2、c3只是一个“名字”,删除的时候不会触发,这是错误的理解,只是因为还有对象指向该类才没有触发,举例:
>>> a1 = C()
我是__init__方法,我被调用了。
>>> a2 = a1
>>> a3 = a2
>>> a4 = a1
>>> del a4
>>> del a3
>>> del a1
>>> del a2
我是__del__方法,我被调用了。
上例能看出,即使在a2之前先删除a1,也并不会触发垃圾回收机制;
2.
>>> class New_int(int):
def __add__(self,other):
return int.__sub__(self,other)
def __sub__(self,other):
return int.__add__(self,other)
>>> a = New_int(5)
>>> b = New_int(3)
>>> a+b
2
(未完)