• 进一步认识__new__和__call__


    1.关于__init__

    class F00(object):
    def __init__(self,name):
    self.name = name
    print("Foo--init--")
    def __new__(cls, *args, **kwargs):
    print("Foo--new--")
    return object.__new__(cls)#cls表示将Foo类传进__new__方法中,表示继父类的__new__方法



    f= F00("name")
    #当存在return object.__new__(cls)时,先后输出Foo--new--和Foo--init--,说明__new__执行在__init__之前
    #当去掉return object.__new__(cls)时,只输出Foo--new--,说明__init__实例时没有被实例
    #总结:__new__方法是类里面自带的,new是用户来创建实例的,默认不写,可以重写
    #作用:在实例化时会先于__init__执行,我们想在实例化之前




    2.关于__call__

    class MyType(type):
    def __init__(self,what,bases=None,dict=None):
    super(MyType, self).__init__(what,bases,dict)
    def __call__(self, *args, **kwargs):
    obj=self.__new__(self,*args, **kwargs)
    self.__init__(obj)

    class Foo(object):#底层是通过MyType类的 __init__方法实现的
    __metaclass__ =MyType
    def __init__(self,name):#底层是通过MyType类的__call__方法的self.__init__(obj)实现的
    self.name = name
    def __new__(cls, *args, **kwargs):
    return object.__new__(cls)#底层是通过MyType类的__call__方法的obj=self.__new__(self,*args, **kwargs)实现的



    obj=Foo("name")#执行创建Foo的实例其实是执行MyType类的__call__方法
    #__call__作用时用于创建__new__的

  • 相关阅读:
    EasyUI combogrid 赋多个值
    EasyUI 打印当前页
    EasyUI 获取行ID,符合条件的添加样式
    JS 调用存储过程传递参数
    彻底解决Request Too Long的问题
    SQL处理XML
    DataTable排序
    EasyUI 动态生成列加分页
    SQL2012 分页(最新)
    计算数据库中各个表的数据量和每行记录所占用空间
  • 原文地址:https://www.cnblogs.com/zfquan/p/7568105.html
Copyright © 2020-2023  润新知