Python 之__new__

new()是在新式类中新出现的方法,它作用在构造方法init()建造实例之前,可以这么理解,在Python 中存在于类里面的构造方法init()负责将类的实例化,而在init()调用之前,new()决定是否要使用该init()方法,因为new()可以调用其他类的构造方法或者直接返回别的对象来作为本类的实例。

new()方法的特性

new()方法是在类准备将自身实例化时调用。

new()方法始终都是类的静态方法,即使没有被加上静态方法装饰器

实例

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
class Person(object):

def __init__(self, name, age):
self.name = name
self.age = age

def __new__(cls, name, age):
if 0 < age < 150:
return object.__new__(cls)
# return super(Person, cls).__new__(cls)
else:
return None

def __str__(self):
return '{0}({1})'.format(self.__class__.__name__, self.__dict__)

print(Person('Tom', 10))
print(Person('Mike', 200))

结果:

1
2
Person({'age': 10, 'name': 'Tom'})
None

Python3和 Python2中new使用不同

Python2的写法:

注意 Python 版本大于等于2.7才支持

1
2
3
4
5
6
class Singleton(object):
def __new__(cls,*args, **kwargs):
if not hasattr(cls,'_inst'):
print(cls)
cls._inst = super(Singleton, cls).__new__(cls,*args,**kwargs)
return cls._inst

Python3的写法

1
2
3
4
5
6
class Singleton(object):
def __new__(cls,*args, **kwargs):
if not hasattr(cls,'_inst'):
print(cls)
cls._inst = super(Singleton, cls).__new__(cls)
return cls._inst

如果Python3的写法跟Python2写法一样,那么倒数第二行会报错”TypeError: object() takes no parameters”


Python 之__new__
https://flepeng.github.io/021-Python-42-核心概念-Python-之-new/
作者
Lepeng
发布于
2021年7月30日
许可协议