最近在看小甲魚的python視頻,在講到魔法方法__new__時,用了一段例子
class CapStr(str):
def __new__(cls, string):
string = string.upper()
return str.__new__(cls, string)
感覺不是很明白,查看很多例子加自己測試後作出如下結論:
首先要明確的是__new__方法一定要返回一個實例對象,所以這也就是爲什麼不能直接 return string 的原因,因爲如果
直接return string,我們可以做個測試:
這裏就有問題了,我們執行了 a = CapStr('i love china')之後,a不應該是個CapStr類型的對象嗎,爲什麼type是‘str’呢,原因就是因爲我們返回的是return string。所以 __new__方法一定要返回一個實例對象的,只有這樣,才能執行後面的__init__方法。
那麼還有一個問題,爲什麼要返回 return str.__new__(cls, string)呢,爲什麼要這麼寫呢?我查了網上有人說了這麼一句話,只有調用父類的__new__方法,返回的纔是當前類的實例對象,對此種說法我有點懷疑,並自己通過測試代碼得到如下結論:
class A:
pass
class B:
def __new__(cls):
return A.__new__(cls)
代碼中A和B沒有任何的繼承關係,那我們運行得出什麼結論呢?如下圖:
結果可知,c的類型仍然是B,所以感覺return 中返回的僅僅是借用某一個類(A)中的__new__方法實現了返回當前參數類型的實例對象而已,並不會在意是否是其父類、調用哪個類的__new__方法。
最後聲明,__new__(cls)方法,需要的cls參數一定是當前的類,此處的cls可以是任何字符,返回的一定是個實例對象,纔會執行後面的__init__方法。