Python 中的__new__(),__init__(),__call__()

__new__方法:类级别的方法

 特性:
1.是在类准备将自身实例化时调用,并且至少需要传递一个参数cls, 此参数在实例化时由python解释器自动提供;

2.始终是类的静态方法,即使没有被加上静态方法装饰器;

3.必须要有返回值,返回实例化出来的实例;在自己实现__new__()时需要注意:可以return父类(通过super(当前类名,cls)).__new__出来的实例,
或者直接是object的__new__出来的实例

class A(object):
    pass
 
a=A()       # 默认调用父类object的__new__()方法来构造该类的实例
print (a)   # 返回的是<__main__.A object at 0x0000024352732630>

重写__new__方法 

class A(object):
 
    def __new__(cls):
        "重写__new__方法"
        return "abc"
 
a=A()
print (a)        # 'abc',实例化对象取决于__new__方法,__new__返回什么就是什么
print (type(a))  # <class 'str'>

通过__new__()方法实现单例(注: 单例模式是指确保某一个类只有一个实例对象存在)

class Singleton(object):
 
    def __new__(cls,*args,**kwargs):
        if not hasattr(cls,"_instance"):
            cls._instance=super(Singleton,cls).__new__(cls)
        return cls._instance
 
a=Singleton()
b=Singleton()
c=Singleton()
print (a)
print (b)
print (c)
 
输出结果:
<__main__.Singleton object at 0x000002474C92D550>
<__main__.Singleton object at 0x000002474C92D550>
<__main__.Singleton object at 0x000002474C92D550>
————————————————
版权声明:本文为CSDN博主「鱼跃龙」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_37579123/article/details/89515577

__init__方法:实例级别的方法

特性:
1.有一个参数self, 该self参数就是__new__()返回的实例;

2.__init__()在__new()的基础上完成初始化动作,不需要返回值;

3.若__new__()没有正确返回当前类cls的实例,那__init__()将不会被调用

4.创建的每个实例都有自己的属性,方便类中的实例方法调用;

对比下面代码理解会更加清晰:

class B():
    def __new__(cls):
        print ("__new__方法被执行")
 
    def __init__(self):
        print ("__init__方法被执行")
 
b=B()   
结果:
__new__方法被执行
class B():
    def __new__(cls):
        print ("__new__方法被执行")
        return super(B,cls).__new__(cls)
 
    def __init__(self):
        print ("__init__方法被执行")
 
b=B()
结果:
__new__方法被执行
__init__方法被执行

__call__方法:特殊方法

特性:

__call__允许一个类的实例像函数一样被调用。实质上说,这意味着 x() 与 x.__call__() 是相同的。注意 __call__ 参数可变。这意味着你可以定义 __call__ 为其他你想要的函数,无论有多少个参数。callable()方法可以判断某对象是否可以被调用。

__call__ 在那些类的实例经常改变状态的时候会非常有效。调用这个实例是一种改变这个对象状态的直接和优雅的做法。

如:

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
e = Entity(1, 2, 3)
print(e.x)
print(e.y)

e(4, 5)
print(e.x)
print(e.y)



————————————————
原文链接:https://blog.csdn.net/qq_35462323/article/details/89307534

原文链接:https://blog.csdn.net/weixin_37579123/article/details/89515577

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值