美文网首页
魔术方法、特殊方法

魔术方法、特殊方法

作者: idri | 来源:发表于2017-09-05 15:57 被阅读0次

    __slots__

    默认情况下Python用一个字典来保存一个对象的实例属性,字典浪费了很多内存。Python不能在对象创建时直接分配一个固定量的内存来保存所有的属性。因此如果你创建许多对象(我指的是成千上万个),它会消耗掉很多内存。
    可以使用__slots__来告诉Python不要使用字典,而且只给一个固定集合的属性分配空间。

    Python允许在定义class的时候,定义一个特殊的__slots__变量,来限制该class能添加的属性:

    >>> class Student(object):
    ...     __slots__ = ('name', 'age') # 用tuple定义允许绑定的属性名称
    

    __slots__定义的属性仅对当前类起作用,对继承的子类是不起作用的
    除非在子类中也定义slots,这样,子类允许定义的属性就是自身的__slots__加上父类的__slots__

    http://pycoders-weekly-chinese.readthedocs.io/en/latest/issue6/a-guide-to-pythons-magic-methods.html

    __new__([cls, ...) 是一个对象实例化时第一个调用的方法,他的第一个参数是这个类,其他参数用来传递给__init__方法

    __init__(self, […)此方法为类的初始化方法。当构造函数被调用的时候的任何参数都将会传给它。(比如如果我们调用 x = SomeClass(10, 'foo')),那么 init 将会得到两个参数10和foo。

    __del__(self) 如果 __new____init__ 是对象的构造器的话,那么__del__ 就是析构器。它不实现语句 del x (以上代码将不会翻译为x.__del__())。它定义的是当一个对象进行垃圾回收时候的行为。当一个对象在删除的时需要更多的清洁工作的时候此方法会很有用,比如套接字对象或者是文件对象。
    __dict__
    对象的属性储存在对象的__dict__属性中。__dict__为一个词典,键为属性名,对应的值为属性本身。

    #会话管理器
    #enter:定义当使用with语句定义一个代码块时会话管理器应该做什么。
    
    #exit:定义当一个代码块被执行或者终止后会话管理器应该做什么。
    
    class FileObject(object):
        def __init__(self, filepath='sample.txt'):
            self.file = open(filepath, 'r+')
        def __enter__(self): # 与with语句对应
            return self.file
        def __exit__(self, exc_type, exc_val, exc_tb):
            self.file.close()
            del self.file
    with FileObject() as fp:
        print fp.read()
    

    __getattr__:查询不在dict系统中的对象属性或者对象方法。

    >>> print(s) # 调用__str__方法
    Student object (name: Michael)
    >>> s() # 调用__call__方法
    Student object (name: Michael)
    
    class Entity:
        '''调用实体来改变实体的位置。'''
        def __init__(self, size, x, y):
            self.x, self.y = x, y
            self.size = size
        def __call__(self, x, y):
            '''改变实体的位置'''
            self.x, self.y = x, y
        def __getitem__(self, item):
            return '返回值(__getitem__, 使用索引访问某个元素)'
        def __getattr__(self, item):
            return '此实例没有这个属性{0}'.format(item)
    
    a = Entity('大小',2,3)
    
    print a.x  # 2
    print a.size  # 大小
    a.x = 8
    print a.x # 8
    print a[4] # 返回值(__getitem__, 使用索引访问某个元素
    
    print a.sdfa #此实例没有这个属性sdfa
    

    相关文章

      网友评论

          本文标题:魔术方法、特殊方法

          本文链接:https://www.haomeiwen.com/subject/suoujxtx.html