_new_的作用
在python中_new_方法与_init_方法类似,但是如果两都存在那么_new_闲执行。在基础类object中,_new_被定义成了一个静态方法,并且需要传递一个参数cls。Cls表示需实例化的类,此参数在实例化时由Python解析器自动提供。new()是在新式类中新出现的方法,它作用在构造方法init()建造实例之前,可以这么理解,在Python 中存在于类里面的构造方法init()负责将类的实例化,而在init()调用之前,new()决定是否要使用该init()方法,因为new()可以调用其他类的构造方法或者直接返回别的对象来作为本类 的实例。 New(方法的特性)new()方法是在类准备将自身实例化时调用。 new()方法始终都是类的静态方法,即使没有被加上静态方法装饰器。实例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))结果:Person({'age': 10, 'name': 'Tom'})NonePython3和python2中_new_使用不同Python2的写法注意python版本大于等于2.7才支持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._instPython3的写法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"