Python- 反射 及部份內置屬性方法

@property
類的靜態屬性,封裝內部具體實現細節,調用的時候類似調用數據屬性。既可以訪問類屬性,也可以訪問實例屬性

  ![](https://s1.51cto.com/images/blog/201906/08/6de11e5b657bbb1c6e02f4ed64821fa7.png?x-oss-process=image/watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=)

@classmethod
類方法

  ![](https://s1.51cto.com/images/blog/201906/08/d36f46a721750e99047808d30276f111.png?x-oss-process=image/watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=)

@staticmethod
類的工具包,不能使用類變量和實例變量

Python- 反射 及部份內置屬性方法

繼承順序

Python- 反射 及部份內置屬性方法

第二種

Python- 反射 及部份內置屬性方法

繼承、多態、封裝

多態:在不同的類實例化得到的對象,調用同一個方法,執行的邏輯不同

封裝
封裝數據:將數據隱藏起來這不是目的。隱藏起來然後對外提供操作該數據的接口,然後我們可以在接口附加上對該數據操作的限制,以此完成對數據屬性操作的嚴格控制。
封裝方法:目的是隔離複雜度

封裝在於明確區分內外,使得類實現者可以修改封裝內的東西而不影響外部調用者的代碼;而外部使用用者只知道一個接口(函數),只要接口(函數)名、參數不變,使用者的代碼永遠無需改變。這就提供一個良好的合作基礎——或者說,只要接口這個基礎約定不變,則代碼改變不足爲慮。

反射

反射 主要是指程序可以訪問、檢測和修改它本身狀態或行爲的一種能力(自省)。

`getattr(object, name, default=None)```:判斷object中有沒有一個name字符串對應的方法或屬性

Python- 反射 及部份內置屬性方法

hasattr(object,'name') - 檢測是否含有某屬性 

Python- 反射 及部份內置屬性方法

setattr(object,name,True)  - 設置屬性\

Python- 反射 及部份內置屬性方法

delattr(object,'name') - 刪除屬性

Python- 反射 及部份內置屬性方法

基於反射- 動態導入模塊

Python- 反射 及部份內置屬性方法

內置屬性方法

getattrdelattr , setattr

getattr :一個對象在調不存在的屬性時候,就會自動觸發。
Python- 反射 及部份內置屬性方法

delattr : 一個對象刪除類屬性或對象屬性時候,會觸發

setattr : 在設置屬性或新增屬性時候,默認就會觸發 setattr ,如果在創建類的時候重新定義了setattr方法,要寫上操作屬性字典代碼,不寫就增加屬性不成功
Python- 反射 及部份內置屬性方法

利用上述幾個內置方法,可以二次加工標準類型。比如重新定義setattr,在新增屬性之前加點自定義參數

包裝一個類型通常是對已存在的類型的一些定製,這種做法可以新建,修改或刪除原有產品的功能。其它的則保持原樣。授權的過程,即是所有更新的功能都是由新類的某部分來處理,但已存在的功能就授權給對象的默認屬性。

實現授權的關鍵點就是覆蓋getattr方法

Python- 反射 及部份內置屬性方法

setitem,getitem,delitem 用字典方式調用屬性的時候就會觸發。如:kk['name']

用點(.)方式調用屬性會觸發 getattr等方法。如:kk.name
Python- 反射 及部份內置屬性方法

str,repr,:改變對象的字符串顯示str,repr
自定製格式化字符串format

str函數或者print函數--->obj.str()
repr或者交互式解釋器--->obj.repr()
如果str沒有被定義,那麼就會使用repr來代替輸出
注意:這倆方法的返回值必須是字符串,否則拋出異常

slots

slots是一個類變量,變量值可以是列表,元祖,或者可迭代對象,也可以是一個字符串(意味着所有實例只有一個數據屬性)

使用點來訪問屬性本質就是在訪問類或者對象的dict屬性字典(類的字典是共享的,而每個實例的是獨立的),字典會佔用大量內存,如果有一個類,屬性很少,但是實例很多,爲了節省內存可以使用slots取代實例的dict。(可以說是用來作爲一個內存優化工具)

定義了slots後的類不再 支持一些普通類特性了,比如多繼承

Python- 反射 及部份內置屬性方法

del

析構方法,當對象在內存中被釋放時,自動觸發執行。

注:如果產生的對象僅僅只是python程序級別的(用戶級),那麼無需定義del,如果產生的對象的同時還會向操作系統發起系統調用,即一個對象有用戶級與內核級兩種資源,比如(打開一個文件,創建一個數據庫鏈接),則必須在清除對象的同時回收系統資源,這就用到了del

nextiter實現迭代器協議

Python- 反射 及部份內置屬性方法

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章