Python中__new__()方法適應(yīng)及注意事項(xiàng)詳解
前言
new() 方法在 Python 中是一個(gè)相對(duì)高級(jí)且特殊的構(gòu)造方法,用于創(chuàng)建并返回類的新實(shí)例。
與 init() 方法不同,new() 是在實(shí)例創(chuàng)建之前被調(diào)用的,而 init() 則是在實(shí)例創(chuàng)建之后被調(diào)用的。了解 new() 方法對(duì)于理解 Python 對(duì)象的創(chuàng)建過程以及實(shí)現(xiàn)某些設(shè)計(jì)模式(如單例模式、工廠模式等)非常重要。
基本用法
new() 方法是一個(gè)靜態(tài)方法,因此需要使用 @staticmethod 裝飾器(雖然在定義 new 時(shí)不需要顯式地這樣做,因?yàn)樗悄J(rèn)被視為靜態(tài)方法的)。它的第一個(gè)參數(shù)通常是類本身(習(xí)慣上命名為 cls),隨后是其他傳遞給類構(gòu)造器的參數(shù)。
class MyClass:
def __new__(cls, *args, **kwargs):
print("Creating a new instance of MyClass")
instance = super(MyClass, cls).__new__(cls) # 調(diào)用父類的 __new__ 方法來(lái)創(chuàng)建實(shí)例
return instance
def __init__(self, value):
print("Initializing MyClass instance")
self.value = value
# 實(shí)例化 MyClass
obj = MyClass(10)
輸出:
Creating a new instance of MyClass
Initializing MyClass instance
返回值
new() 方法必須返回一個(gè)類的實(shí)例。如果 new() 不返回任何內(nèi)容(即返回 None),那么 init() 方法將不會(huì)被調(diào)用。
class MyClass:
def __new__(cls, *args, **kwargs):
print("Creating a new instance of MyClass")
# 不返回任何內(nèi)容(即隱式返回 None)
def __init__(self, value):
print("Initializing MyClass instance")
self.value = value
# 實(shí)例化 MyClass,注意 __init__ 不會(huì)被調(diào)用
obj = MyClass(10) # 只會(huì)輸出 "Creating a new instance of MyClass"
單例模式
new() 方法的一個(gè)常見用途是實(shí)現(xiàn)單例模式,確保一個(gè)類只有一個(gè)實(shí)例。
class Singleton:
_instance = None
def __new__(cls, *args, **kwargs):
if not cls._instance:
cls._instance = super(Singleton, cls).__new__(cls)
return cls._instance
def __init__(self, value=None):
if not hasattr(self, 'initialized'): # 確保 __init__ 只被調(diào)用一次
self.value = value
self.initialized = True
# 嘗試創(chuàng)建多個(gè)實(shí)例
obj1 = Singleton(1)
obj2 = Singleton(2)
print(obj1 is obj2) # 輸出: True
print(obj1.value) # 輸出: 1,因?yàn)?__init__ 只會(huì)在第一次實(shí)例化時(shí)被調(diào)用
自定義對(duì)象創(chuàng)建
通過 new() 方法,可以自定義對(duì)象的創(chuàng)建過程,例如從工廠方法返回不同類型的對(duì)象。
class FactoryClass:
@staticmethod
def __new__(cls, *args, **kwargs):
if kwargs.get('type') == 'A':
return ClassA(*args, **kwargs)
elif kwargs.get('type') == 'B':
return ClassB(*args, **kwargs)
else:
raise ValueError("Unknown type")
class ClassA:
def __init__(self, value):
self.value = value
print(f"ClassA instance created with value: {value}")
class ClassB:
def __init__(self, value):
self.value = value
print(f"ClassB instance created with value: {value}")
# 使用工廠類創(chuàng)建不同類型的實(shí)例
obj_a = FactoryClass(type='A', value=10)
obj_b = FactoryClass(type='B', value=20)
注意事項(xiàng)
性能考慮:new() 是在對(duì)象創(chuàng)建之前調(diào)用的,因此它應(yīng)該盡可能快地執(zhí)行。
繼承:在子類中使用 new() 時(shí),通常要調(diào)用父類的 new() 方法來(lái)確保對(duì)象被正確創(chuàng)建。
不可變性:如果類是不可變的(如元組、字符串等),則通常不需要重寫 init(),但可能需要重寫 new() 來(lái)定制對(duì)象的創(chuàng)建。
通過理解 new() 方法,你可以更深入地掌握 Python 對(duì)象的創(chuàng)建和初始化過程,并設(shè)計(jì)出更加靈活和強(qiáng)大的類結(jié)構(gòu)。
總結(jié)
到此這篇關(guān)于Python中__new__()方法適應(yīng)及注意事項(xiàng)的文章就介紹到這了,更多相關(guān)Python __new__()方法詳解內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Python中的?__init__、__new__?和?__call__示例詳解
- Python中的魔術(shù)方法__new__詳解
- python中__new__和__init__的實(shí)現(xiàn)
- python __init__與 __new__的區(qū)別
- Python中class內(nèi)置方法__init__與__new__作用與區(qū)別解析
- 詳解Python中__new__方法的作用
- Python 中類的構(gòu)造方法 __New__的妙用
- Python中__new__和__init__的區(qū)別與聯(lián)系
- Python 用__new__方法實(shí)現(xiàn)單例的操作
- python中__new__函數(shù)的具體使用
相關(guān)文章
基于Python實(shí)現(xiàn)一個(gè)春節(jié)倒計(jì)時(shí)腳本
春節(jié)即將到來(lái),本文將為大家介紹一個(gè)通過Python實(shí)現(xiàn)的春節(jié)倒計(jì)時(shí)腳本,文中的示例代碼簡(jiǎn)潔易懂,感興趣的小伙伴可以自己動(dòng)手嘗試一下2022-01-01
Python中使用裝飾器來(lái)優(yōu)化尾遞歸的示例
這里我們用典型的斐波那契數(shù)列作為例子,來(lái)展示Python中使用裝飾器來(lái)優(yōu)化尾遞歸的示例,需要的朋友可以參考下2016-06-06
python3.10及以上版本編譯安裝ssl模塊的詳細(xì)過程
最近搞安裝ssl模塊每天都弄到很晚,所以這里給大家整理下,這篇文章主要給大家介紹了關(guān)于python3.10及以上版本編譯安裝ssl模塊的詳細(xì)過程,文中介紹的非常詳細(xì),需要的朋友可以參考下2023-05-05
Matplotlib使用Cursor實(shí)現(xiàn)UI定位的示例代碼
這篇文章主要介紹了Matplotlib使用Cursor實(shí)現(xiàn)UI定位的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03
在VSCode中添加Python解釋器并安裝Python庫(kù)的方法
這篇文章主要介紹了在VSCode中添加Python解釋器并安裝Python庫(kù)的方法,本文分步驟通過圖文并茂的形式給大家介紹的非常詳細(xì),需要的朋友可以參考下2023-02-02
對(duì)sklearn的使用之?dāng)?shù)據(jù)集的拆分與訓(xùn)練詳解(python3.6)
今天小編就為大家分享一篇對(duì)sklearn的使用之?dāng)?shù)據(jù)集的拆分與訓(xùn)練詳解(python3.6),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧2018-12-12
python+pytest接口自動(dòng)化之日志管理模塊loguru簡(jiǎn)介
python中有一個(gè)用起來(lái)非常簡(jiǎn)便的第三方日志管理模塊--loguru,不僅可以避免logging的繁瑣配置,而且可以很簡(jiǎn)單地避免在logging中多進(jìn)程多線程記錄日志時(shí)出現(xiàn)的問題,甚至還可以自定義控制臺(tái)輸出的日志顏色,接下來(lái)我們來(lái)學(xué)習(xí)怎么使用loguru模塊進(jìn)行日志管理2022-05-05

