python對象初始化
㈠ python在類中初始化另一個類
第一個問題:queryservice繼承了service,第一個問題處的意思是同樣把service里的init method原封不動繼承過來。沒有保存什麼值。
第二個問題:你用init初始化時後面的括弧里是self和request,而request你給的默認值是none,也就是說編譯完了用的時候,我可以QueryService(request='xxxx') 也可以直接QueryService()。而self.request = request的意思是把用戶輸入的request,也就是'xxx'保存到內部。
解釋的不太清楚,建議閱讀一下各種python書面向對象編程這塊,lz問的都是最基礎的問題
㈡ 關於python的實例方法問題
題主你好,
python中創建新實例的時候, 如果相應的類中定義了__init__()方法的話, 會自動調用這個方法. 你可能認為名稱"init"和"__init__"差不多, 但計算機其實是個很笨的東西, 它會完全按照設計去執行. 也就是說,在設計的時候就已經定死了, 默認情況下, 創建新實例的時候, 會自動調用類中定義的__init__()方法, 只要你的方法名和__init__有一點不一樣也不行.
下圖是我在官網上找的關於__init__()調用的簡單說明:
高亮部分說的大概意思就是上面講的,如果相應類中定義了__init__()方法,則在創建該類實例的時候會自動調用裡面定義的__init__()方法.
-----
希望可以幫到題主, 歡迎追問.
㈢ 詳解Python中的__new__、__init__、__call__三個特殊方法
__new__: 對象的創建,是一個靜態方法,第一個參數是cls。(想想也是,不可能是self,對象還沒創建,哪來的self)
__init__ : 對象的旦胡初始化, 是一個實例方法,第一個參數是self。
__call__ : 對象可call,注意不是類,是對象。
先有創建,才有初始化。即先__new__,而後__init__。
上面說的不好理解,看例子。
1.對於__new__
可以看到,輸出來是一個Bar對象。
__new__方法在類定義中不是必須寫的,如果沒定義,默認會調用object.__new__去創建一個對象。如果定義了,就是override,可以custom創建對象的行為。
聰明的讀者可能想到,既然__new__可以custom對象的創建,那我在這里做一下手腳,每次創建對象都返回同一個,那不就是單例模式了嗎?沒錯,就是這樣。可以觀摩《飄逸的模培攔python - 單例中返模式亂彈》
定義單例模式時,因為自定義的__new__重載了父類的__new__,所以要自己顯式調用父類的__new__,即object.__new__(cls, *args, **kwargs),或者用super()。,不然就不是extend原來的實例了,而是替換原來的實例。
2.對於__init__
使用Python寫過面向對象的代碼的同學,可能對 __init__ 方法已經非常熟悉了,__init__ 方法通常用在初始化一個類實例的時候。例如:
這樣便是__init__最普通的用法了。但__init__其實不是實例化一個類的時候第一個被調用 的方法。當使用 Persion(name, age) 這樣的表達式來實例化一個類時,最先被調用的方法 其實是 __new__ 方法。
3.對於__call__
對象通過提供__call__(slef, [,*args [,**kwargs]])方法可以模擬函數的行為,如果一個對象x提供了該方法,就可以像函數一樣使用它,也就是說x(arg1, arg2...) 等同於調用x.__call__(self, arg1, arg2) 。模擬函數的對象可以用於創建防函數(functor) 或代理(proxy).
總結,在Python中,類的行為就是這樣,__new__、__init__、__call__等方法不是必須寫的,會默認調用,如果自己定義了,就是override,可以custom。既然override了,通常也會顯式調用進行補償以達到extend的目的。
這也是為什麼會出現"明明定義def _init__(self, *args, **kwargs),對象怎麼不進行初始化"這種看起來詭異的行為。(注,這里_init__少寫了個下劃線,因為__init__不是必須寫的,所以這里不會報錯,而是當做一個新的方法_init__)
㈣ __init__ 為什麼python類需要初始化
通常構造一個類,用 init 初始化:
為什麼python類需要初始化
1.python 類初始化屬性 def __init__() 中定義,實例化對象後可直接調用
2.python 類非初始化屬性在 def func() 中定義,實例化對象後, 先調用調用函數,再調用屬性
結果: