亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python中的?__init__、__new__?和?__call__示例詳解

 更新時間:2025年09月01日 10:26:58   作者:哈拉索zbc  
這篇文章主要介紹了Python中__init__、__new__?和?__call__的相關(guān)資料,它們分別負責(zé)對象創(chuàng)建、初始化和調(diào)用,用于實現(xiàn)單例模式、裝飾器等高級功能,需要的朋友可以參考下

這三個特殊方法是 Python 面向?qū)ο缶幊讨械暮诵臉?gòu)造機制,分別在對象生命周期的不同階段發(fā)揮作用:

1.__init__方法:對象初始化器

  • 作用:初始化新創(chuàng)建的實例對象

  • 調(diào)用時機:在 __new__ 創(chuàng)建實例之后自動調(diào)用

  • 參數(shù):第一個參數(shù)必須是 self(指向新實例)

  • 返回值:無(必須返回 None

  • 核心職責(zé)

    • 設(shè)置實例屬性的初始值

    • 執(zhí)行必要的初始化操作

    • 不負責(zé)創(chuàng)建對象本身

      class Person:
          def __init__(self, name, age):
              print("__init__ called")
              self.name = name  # 設(shè)置實例屬性
              self.age = age
      
      # 使用
      p = Person("Alice", 30)
      # 輸出:__init__ called
      print(p.name)  # Alice

      關(guān)鍵點

    • 每個類可以定義自己的 __init__

    • 如果未定義,繼承父類的 __init__

    • 可以調(diào)用父類的 __init__super().__init__(args)

    • 不是構(gòu)造函數(shù)(實際創(chuàng)建對象的是 __new__

2.__new__方法:對象創(chuàng)建器

  • 作用:實際創(chuàng)建類的新實例

  • 調(diào)用時機:在 __init__ 之前自動調(diào)用

  • 參數(shù):第一個參數(shù)必須是 cls(指向當前類)

  • 返回值:必須返回創(chuàng)建好的實例對象

  • 核心職責(zé)

    • 控制實例創(chuàng)建過程

    • 決定是否返回新實例或已有實例

    • 可以返回其他類的實例

      class Singleton:
          _instance = None
          
          def __new__(cls, *args, **kwargs):
              print("__new__ called")
              if not cls._instance:
                  # 創(chuàng)建新實例(調(diào)用父類的__new__)
                  cls._instance = super().__new__(cls)  
              return cls._instance  # 返回實例(新或已有)
      
          def __init__(self, value):
              print("__init__ called")
              self.value = value
      
      # 使用
      s1 = Singleton(10)
      # 輸出: __new__ called -> __init__ called
      s2 = Singleton(20)
      # 輸出: __new__ called -> __init__ called
      print(s1 is s2)  # True(相同實例)
      print(s1.value)  # 20(注意:__init__被再次調(diào)用?。?
      

      關(guān)鍵點

    • 必須返回有效的對象實例

    • 如果返回非當前類實例,__init__ 不會被調(diào)用

    • 常用場景:單例模式、不可變類型子類化

    • 元類中 __new__ 創(chuàng)建的是類對象本身

3.__call__方法:對象調(diào)用器

  • 作用:使類的實例可以像函數(shù)一樣被調(diào)用

  • 調(diào)用時機:當實例后加 () 時自動調(diào)用

  • 參數(shù):第一個參數(shù)必須是 self(指向?qū)嵗?/p>

  • 返回值:任意類型值

  • 核心職責(zé)

    • 定義實例作為函數(shù)的行為

    • 實現(xiàn)裝飾器類

    • 創(chuàng)建有狀態(tài)的函數(shù)對象

class Adder:
    def __init__(self, base):
        self.base = base
    
    def __call__(self, x):
        print("__call__ invoked")
        return self.base + x

# 使用
add5 = Adder(5)  # 創(chuàng)建可調(diào)用對象
print(add5(3))   # 輸出: __call__ invoked -> 8
print(add5(10))  # 輸出: __call__ invoked -> 15

高級應(yīng)用:裝飾器類

class TraceCalls:
    def __init__(self, func):
        self.func = func
        self.call_count = 0
    
    def __call__(self, *args, **kwargs):
        self.call_count += 1
        print(f"Call #{self.call_count} to {self.func.__name__}")
        return self.func(*args, **kwargs)

@TraceCalls
def multiply(a, b):
    return a * b

print(multiply(3, 4))
# 輸出: 
# Call #1 to multiply
# 12

print(multiply(5, 6))
# 輸出:
# Call #2 to multiply
# 30

三者的協(xié)作流程

class Example:
    def __new__(cls, *args, **kwargs):
        print("1. __new__: Creating instance")
        instance = super().__new__(cls)
        return instance
    
    def __init__(self, value):
        print("2. __init__: Initializing instance")
        self.value = value
    
    def __call__(self, multiplier):
        print("3. __call__: Invoking instance")
        return self.value * multiplier

# 完整生命周期
e = Example(10)  
# 輸出:
# 1. __new__: Creating instance
# 2. __init__: Initializing instance

result = e(5)    
# 輸出:
# 3. __call__: Invoking instance
print(result)  # 50

關(guān)鍵對比表

特性__new____init____call__
角色對象創(chuàng)建器對象初始化器對象調(diào)用器
調(diào)用時機創(chuàng)建實例時(最先)__new__ 之后實例被調(diào)用時
首參數(shù)cls (類引用)self (實例引用)self (實例引用)
返回值必須返回實例對象必須返回 None可返回任意值
主要用途控制實例創(chuàng)建過程初始化實例屬性使實例可像函數(shù)一樣調(diào)用
是否必需不定義則用 object.__new__不定義則跳過初始化不定義則實例不可調(diào)用
典型場景單例模式、不可變類型常規(guī)對象初始化裝飾器類、函數(shù)對象

高級應(yīng)用場景

1. 不可變類型擴展

class UppercaseStr(str):
    def __new__(cls, value):
        # 在創(chuàng)建前修改值
        return super().__new__(cls, value.upper())

s = UppercaseStr("hello")
print(s)  # "HELLO"(不可變對象在創(chuàng)建時確定值)

2. 對象工廠

class Animal:
    def __new__(cls, animal_type, *args):
        if animal_type == "dog":
            return Dog(*args)
        elif animal_type == "cat":
            return Cat(*args)
        raise ValueError(f"Unknown animal: {animal_type}")

class Dog:
    def __init__(self, name):
        self.name = name

class Cat:
    def __init__(self, name):
        self.name = name

d = Animal("dog", "Buddy")
print(type(d), d.name)  # <class '__main__.Dog'> Buddy

3. 帶狀態(tài)的裝飾器

class Retry:
    def __init__(self, max_attempts=3):
        self.max_attempts = max_attempts
    
    def __call__(self, func):
        def wrapper(*args, **kwargs):
            for attempt in range(1, self.max_attempts+1):
                try:
                    return func(*args, **kwargs)
                except Exception as e:
                    print(f"Attempt {attempt} failed: {e}")
            raise RuntimeError("All attempts failed")
        return wrapper

@Retry(max_attempts=2)
def risky_operation():
    import random
    if random.random() < 0.7:
        raise ValueError("Random failure")
    return "Success"

print(risky_operation())

常見陷阱與解決方案

1. __init__ 中忘記返回 None

class Mistake:
    def __init__(self):
        return 42  # TypeError: __init__() should return None

2.__new__ 忘記返回實例

class BadClass:
    def __new__(cls):
        print("Forgot to return instance")  # 返回None -> TypeError

3.單例模式中的重復(fù)初始化

解決方案:使用標志位控制

class SafeSingleton:
    _instance = None
    _initialized = False
    
    def __new__(cls):
        if not cls._instance:
            cls._instance = super().__new__(cls)
        return cls._instance
    
    def __init__(self):
        if not self.__class__._initialized:
            # 初始化代碼
            self.__class__._initialized = True

4.__call__ 與 __init__ 參數(shù)混淆

掌握這三個特殊方法的區(qū)別和協(xié)作機制,能夠讓你更精細地控制 Python 對象的整個生命周期,實現(xiàn)更高級的設(shè)計模式。

總結(jié)

到此這篇關(guān)于Python中的 __init__、__new__ 和 __call__的文章就介紹到這了,更多相關(guān)Python __init__、__new__ 和 __call__內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • PyQt5打開文件對話框QFileDialog實例代碼

    PyQt5打開文件對話框QFileDialog實例代碼

    這篇文章主要介紹了PyQt5打開文件對話框QFileDialog實例代碼,分享了相關(guān)代碼示例,小編覺得還是挺不錯的,具有一定借鑒價值,需要的朋友可以參考下
    2018-02-02
  • Django實現(xiàn)文件上傳和下載功能

    Django實現(xiàn)文件上傳和下載功能

    這篇文章主要為大家詳細介紹了Django下完成文件上傳和下載功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • Python3 翻轉(zhuǎn)二叉樹的實現(xiàn)

    Python3 翻轉(zhuǎn)二叉樹的實現(xiàn)

    這篇文章主要介紹了Python3 翻轉(zhuǎn)二叉樹的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • 用python構(gòu)建IP代理池詳解

    用python構(gòu)建IP代理池詳解

    大家好,本篇文章主要講的是用python構(gòu)建IP代理池詳解,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下
    2022-01-01
  • python和opencv實現(xiàn)摳圖

    python和opencv實現(xiàn)摳圖

    這篇文章主要為大家詳細介紹了使用python和opencv實現(xiàn)摳圖,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-07-07
  • SQLite3中文編碼 Python的實現(xiàn)

    SQLite3中文編碼 Python的實現(xiàn)

    下面小編就為大家?guī)硪黄猄QLite3中文編碼 Python的實現(xiàn)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-01-01
  • 解決Pycharm在Debug的時候一直“Connected”沒有下一步動作問題

    解決Pycharm在Debug的時候一直“Connected”沒有下一步動作問題

    這篇文章主要介紹了解決Pycharm在Debug的時候一直“Connected”沒有下一步動作問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • python獲取android設(shè)備的GPS信息腳本分享

    python獲取android設(shè)備的GPS信息腳本分享

    這篇文章主要介紹了python獲取android設(shè)備的GPS信息腳本分享,本文直接給出實現(xiàn)代碼,需要的朋友可以參考下
    2015-03-03
  • python兼容VBA的用法詳解

    python兼容VBA的用法詳解

    這篇文章主要介紹了python兼容VBA的用法詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-09-09
  • python中CURL 和python requests的相互轉(zhuǎn)換實現(xiàn)

    python中CURL 和python requests的相互轉(zhuǎn)換實現(xiàn)

    本文主要介紹了python中CURL 和python requests的相互轉(zhuǎn)換實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03

最新評論