鬼少 发表于 2024-9-29 23:07:49

Python 的__new__(cls) 方法问题

有如下两段代码, 为和带return和不带return, 打印不同?
1) class Person(object):
   
    def __new__(cls):
      print("__new__ called")
      return super().__new__(cls)
   
    def __init__(self):
      print("__init__ called")
                  
a = Person()
输出打印结果:               
'''
__new__ called
__init__ called
'''
2.class Person(object):
   
    def __new__(cls):
      print("__new__ called")
   
   
    def __init__(self):
      print("__init__ called")

                  
a = Person()
输出打印结果:               
'''
__new__ called
'"

FishC 发表于 2024-9-29 23:08:01

我们来分别解析这两段代码。

#### 代码1:
class Person(object):
   
    def __new__(cls):
      print("__new__ called")
      return super().__new__(cls)
   
    def __init__(self):
      print("__init__ called")
         
a = Person()
- `__new__` 方法先被调用,打印 `__new__ called`。
- `__new__` 返回一个新创建的实例。
- 接着,`__init__` 方法被调用,打印 `__init__ called`。

因此,输出结果是:
__new__ called
__init__ called

#### 代码2:
class Person(object):
   
    def __new__(cls):
      print("__new__ called")
   
    def __init__(self):
      print("__init__ called")
         
a = Person()
- `__new__` 方法先被调用,打印 `__new__ called`。
- 但是 `__new__` 方法没有返回实例,返回值默认是 `None`。
- 由于没有实例被创建,所以 `__init__` 方法不会被调用。

因此,输出结果是:
__new__ called

希望这样解释能帮助你理解其中的区别。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。

jackz007 发表于 2024-9-30 00:23:56

本帖最后由 jackz007 于 2024-9-30 12:42 编辑

       __new__() 方法用于创建对象,创建对象是一件非常复杂的事情,究竟需要完成哪些工作,我们根本就不得而知,因而,这个方法无可替代,就是说,必须通过 Python 系统提供的 __new__() 方法来创建新对象;__init__() 是构造方法,是在创建新对象的时候,会被 __new__() 调用的一个方法,用于初始化对象的各个属性,目标很明确,因此,这个方法可以被我们任意拿捏。
       编写 __new__() 方法正确的方式是,以这条语句结尾
return super().__new__(cls)
       或者,用同逻辑其它形式的表达,否则,像代码 2 那样,完全自编一个 __new__() 方法,其结果就是, __new__() 方法根本没有功能,就是说,调用 __new__()方法并不能产生出新的对象,同时,代码 2 中的 __init__() 方法也就成了摆设,因为,__new__() 并没有调用它,也就永远都没有机会被调用到了。

鬼少 发表于 2024-10-7 20:33:18

感谢回答, 非常棒
页: [1]
查看完整版本: Python 的__new__(cls) 方法问题