Fluent Python读书笔记(二)

如何使用特殊方法 (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)

你可能感兴趣的:(fluentpy,读书笔记,python)