python不同版本的_new_不同點(diǎn)總結(jié)
我們都知道python的版本不同,在使用的時(shí)候就有所區(qū)別。鑒于我們推薦小伙伴們選擇python3版本,所以這方面的區(qū)別了解的不是很多。就拿_new_來(lái)說(shuō),在python2和3中的寫法是不一樣的,之前有接觸_new_的小伙伴想必沒(méi)有注意到這個(gè)問(wèn)題。接下來(lái)講講new的基本用法,然后就python不同版本中_new_的區(qū)別帶來(lái)詳解。
new方法接受的參數(shù)雖然也是和init一樣,但init是在類實(shí)例創(chuàng)建之后調(diào)用,而 new方法正是創(chuàng)建這個(gè)類實(shí)例的方法。
class Person(object): """Silly Person""" def __new__(cls, name, age): print '__new__ called.' return super(Person, cls).__new__(cls, name, age) def __init__(self, name, age): print '__init__ called.' self.name = name self.age = age def __str__(self): return '<Person: %s(%s)>' % (self.name, self.age) if __name__ == '__main__': piglei = Person('piglei', 24) print piglei
Python3和 Python2中__new__使用不同
Python3的寫法
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寫法一樣,那么倒數(shù)第二行會(huì)報(bào)錯(cuò)
"TypeError: object() takes no parameters"
根據(jù)上面的運(yùn)行結(jié)果我們可以發(fā)現(xiàn),在python3中強(qiáng)行使用python2的寫法是不可行的。
Python __new__()知識(shí)點(diǎn)擴(kuò)充
__new__() 是一種負(fù)責(zé)創(chuàng)建類實(shí)例的靜態(tài)方法,它無(wú)需使用 staticmethod 裝飾器修飾,且該方法會(huì)優(yōu)先 __init__() 初始化方法被調(diào)用。
一般情況下,覆寫 __new__() 的實(shí)現(xiàn)將會(huì)使用合適的參數(shù)調(diào)用其超類的 super().__new__(),并在返回之前修改實(shí)例。例如:
class demoClass: instances_created = 0 def __new__(cls,*args,**kwargs): print("__new__():",cls,args,kwargs) instance = super().__new__(cls) instance.number = cls.instances_created cls.instances_created += 1 return instance def __init__(self,attribute): print("__init__():",self,attribute) self.attribute = attribute test1 = demoClass("abc") test2 = demoClass("xyz") print(test1.number,test1.instances_created) print(test2.number,test2.instances_created)
輸出結(jié)果為
__new__(): <class '__main__.demoClass'> ('abc',) {}
__init__(): <__main__.demoClass object at 0x0000026FC0DF8080> abc
__new__(): <class '__main__.demoClass'> ('xyz',) {}
__init__(): <__main__.demoClass object at 0x0000026FC0DED358> xyz
0 2
1 2
到此這篇關(guān)于python不同版本的_new_不同點(diǎn)總結(jié)的文章就介紹到這了,更多相關(guān)python不同版本中的_new_有何不同內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用TensorFlow-Slim進(jìn)行圖像分類的實(shí)現(xiàn)
這篇文章主要介紹了使用TensorFlow-Slim進(jìn)行圖像分類的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12Python中實(shí)現(xiàn)結(jié)構(gòu)相似的函數(shù)調(diào)用方法
這篇文章主要介紹了Python中實(shí)現(xiàn)結(jié)構(gòu)相似的函數(shù)調(diào)用方法,本文講解使用dict和lambda結(jié)合實(shí)現(xiàn)結(jié)構(gòu)相似的函數(shù)調(diào)用,給出了不帶參數(shù)和帶參數(shù)的實(shí)例,需要的朋友可以參考下2015-03-03Python實(shí)現(xiàn)求解最大公約數(shù)的五種方法總結(jié)
求最大公約數(shù)是習(xí)題中比較常見的類型,本文小編將給大家提供五種比較常見的算法,都是用Python語(yǔ)言實(shí)現(xiàn)的,感興趣的小伙伴可以了解一下2022-07-07Python?reflect單例模式反射各個(gè)函數(shù)
這篇文章主要介紹了Python?reflect單例模式反射各個(gè)函數(shù),文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值需要的小伙伴可以參考一下2022-06-06用pip給python安裝matplotlib庫(kù)的詳細(xì)教程
這篇文章主要介紹了用pip給python安裝matplotlib庫(kù)的詳細(xì)教程,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-02-02Python?Asyncio庫(kù)之a(chǎn)syncio.task常用函數(shù)詳解
Asyncio在經(jīng)過(guò)一段時(shí)間的發(fā)展以及獲取Curio等第三方庫(kù)的經(jīng)驗(yàn)來(lái)提供更多的功能,目前高級(jí)功能也基本完善。本文主要介紹了Asyncio庫(kù)中asyncio.task常用函數(shù)的使用,需要的可以參考一下2023-03-03