Python 中__new__()和__init__()的区别

枫铃3年前 (2021-09-30)Python226

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

通过__new__()方法实现单例

'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:531509025
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
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>

__init__方法:实例级别的方法

特性:

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

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

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

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

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

'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:531509025
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
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__方法被执行

相关文章

在python函数中参数分类的详细教程

在python函数中参数分类的详细教程

一、参数的定义 1、函...

python中sorted()函数的用法

一. 定义 sorted()函数对所有可迭代的对象进行排序操作 二. 语法 sorted(iterable [, key[, reverse]]])...

Python中的那些“坑”

1.哪个是True&#x...

Python | 5分钟搞定 Python3 元组

Python | 5分钟搞定 Python3 元组

简介 Python3 中元组表现为如下形式: 元组(tuple)是一种静态的(immutable)或者说是不可变(unchangeabl...

用Python获取Linux资源信息的三种方法

方法一:psutil模块 psutil #!usr/bin/env python # -*- coding: utf-8 -*- impor...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。