zoukankan      html  css  js  c++  java
  • python中的内方法

    python中的__new__方法

     
    
    
    1.创建类时先执行type的__init__方法,
    2.当一个类实例化时(创建一个对象)执行type的__call__方法,__call__方法的返回值就是实例化的对象
        __call__内部调用
          -类.__new__方法,创建一个对象
          -类.__init__方法,初始化对象

    实例化对象是谁取决于__new__方法,__new__返回什么就是什么

     __new__() 方法的特性:
    • __new__() 方法是在类准备将自身实例化时调用。
    • __new__() 方法始终都是类的静态方法,即使没有被加上静态方法装饰
    class Foo(object):
        pass
    
    obj=Foo()  #默认是调用该类的直接父类的__new__()方法来构造该类的实例
    print(obj) #打印结果:<__main__.Foo object at 0x000002636FEAA208>
    
    事实上如果(新式)类中没有重写__new__()方法,即在定义新式类时没有重新定义__new__()时,Python默认是调用该类的直接父类的__new__()方法来构造该类的实例,
    如果该类的父类也没有重写__new__(),那么将一直按此规矩追溯至object的__new__()方法,因为object是所有新式类的基类。
    
    class F1(object):
      #重写__new__方法,返回这个重写的__new__方法
        def __new__(cls, *args, **kwargs):
            return 123
    
    obj=F1() #实例化对象是谁取决于__new__方法,__new__返回什么就是什么
    print(obj,type(obj))  #打印结果:123 <class 'int'>
    
    
    class F2(object):
        pass
    
    class F3(object):
        def __new__(cls, *args, **kwargs):
            return F2()
    
    obj=F3()    #实例化对象是谁取决于__new__方法,__new__返回什么就是什么
    print(obj)  #<__main__.F2 object at 0x00000210119BA4A8>
    
    如果要得到当前类的实例,应当在当前类中的 __new__() 方法语句中调用当前类的父类的 __new__() 方法。
    例如,如果当前类是直接继承自 object,那当前类的 __new__() 方法返回的对象应该为:
    def __new__(cls, *args, **kwargs):
        ...
        return object.__new__(cls)
    __new__至少要有一个参数cls,代表要实例化的类,此参数在实例化时由Python解释器自动提供
    __new__必须要有返回值,返回实例化出来的实例,这点在自己实现__new__时要特别注意,可以return父类__new__出来的实例,或者直接是object的__new__出来的实例
    __init__有一个参数self,就是这个__new__返回的实例,__init__在__new__的基础上可以完成一些其它初始化的动作__init__不需要返回值

    有了__call__就可以把对象当作函数一样的调用了。也就是说__call__()的作用是使实例能够像函数一样被调用,同时不影响实例本身的生命周期(__call__()不影响一个实例的构造和析构)。但是__call__可以用来改变实例的内部成员的值。

    #新建一个类
    class Student():        
    #进行初始化        
    def __init__(self, name, age, ):           
         self.name = name            
        self.age = age                
    def __call__(self, age):           
         self.age = age               
    def __str__(self):           
         return f'{self.name}的年龄是{self.age}'  
    
    #实例化一个学生出来
    student1 = Student('bill', 12)print(student1) 
    #现在进行年龄的更改,就可以象调用方法一样的调用了。
    student1(34)print(student1) #=> bill的年龄是34
    

      

    #一个小的总结:
    __new__: 对象的创建,是一个静态方法,第一个参数是cls。有返回值,返回值为对象本身,代码如下
    class MusicPlayer(object):     # 为对象分配内存空间
        def __new__(cls, *args, **kwargs):
        # 1. 创建对象时,new方法会被自动调用
           print("创建对象,分配内存空间")
        # 2. 为对象分配空间
           instance = super().__new__(cls)
        # 3. 返回对象的引用
           return instance
        # 对象初始化,定义实例属性
        def __init__(self):
            print("播放器初始化")  
    # 创建播放器对象
    player = MusicPlayer() 
    print(player)
    

      

    __init__ : 对象的初始化, 是一个实例方法,第一个参数是self,初始化的时候就具有的属性,这个属性可以设默认值。,无返回值
    __call__ : 对象可被掉用,注意不是类,是对象。对象可以被调用,否则是不可以的,这里面的不能设默认值。
    ————————————————
    版权声明:本文为CSDN博主「军械士官长」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
    原文链接:https://blog.csdn.net/junxieshiguan/article/details/82502437
  • 相关阅读:
    355. Design Twitter
    54. Spiral Matrix
    143. Reorder List
    324. Wiggle Sort II
    365. Water and Jug Problem
    洛谷 P3527 [POI2011]MET-Meteors 解题报告
    洛谷 P4592 [TJOI2018]异或 解题报告
    单调序列 解题报告
    洛谷 P4735 最大异或和 解题报告
    洛谷 P1527 [国家集训队]矩阵乘法 解题报告
  • 原文地址:https://www.cnblogs.com/xingkongzhizhu/p/12003029.html
Copyright © 2011-2022 走看看