如何使用特殊方法 (P11特殊方法一览表)
特殊方法的存在是为了被Python解释器调用的,自己并不需要调用它。(所以使用len(object),而不是object.__len__())
如果object是一个自定义类的对象,Python会自己调用其中由你实现的__len__()方法,而如果是Python内置的类型(list, str, bytearray等),CPython会抄个近路,__len__()实际上会直接返回PyVarObject里的ob_size属性。
很多时候,特殊方法的调用时隐式的,for i in x:用的是iter(x)
模拟数值类型
from math import hypot
class Vector:
def __init__(self,x=0,y=0):
self.x=x
self.y=y
'''
__repr__将一个对象用字符串的形式表达出来以便辨认
%r用rper()方法处理对象
%s用str()方法处理对象
%r打印时能够重现它所代表的对象 如:
>>> text = "I am %d years old." % 22
>>> print "I said: %r." % text
I said: 'I am 22 years old.'. // %r 给字符串加了单引号
>>> import datetime
>>> d = datetime.date.today()
>>> print "%r" % d
datetime.date(2017, 11, 5)
'''
def __repr__(self):
return 'Vector(%r,%r)'%(self.x,self.y)
# __abs__返回输入值的绝对值
def __abs__(self):
return hypot(self.x,self.y)
# bool(x)的背后是调用x.__bool__()的结果;如果不存在__bool__方法,那么bool(x)就会尝试调用__len__(),若返回0,bool会返回False
def __bool__(self):
return bool(abs(self))
'''
def __bool__(self):
return bool(self.x or self.y)
更高效
'''
# __add__和__mul__方法返回值都是新创建的向量对象,中缀运算符的基本原则就是不改变操作对象,而是产出一个新的值
def __add__(self,other):
x=self.x+other.x
y=self.y+other.y
return Vector(x,y)
def __mul__(self,scalar):
return Vector(self.x*scalar,self.y*scalar)