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

@classmethod
類方法

@staticmethod
類的工具包,不能使用類變量和實例變量
繼承順序
第二種
繼承、多態、封裝
多態:在不同的類實例化得到的對象,調用同一個方法,執行的邏輯不同
封裝
:
封裝數據
:將數據隱藏起來這不是目的。隱藏起來然后對外提供操作該數據的接口,然后我們可以在接口附加上對該數據操作的限制,以此完成對數據屬性操作的嚴格控制。
封裝方法
:目的是隔離復雜度
封裝在于明確區分內外,使得類實現者可以修改封裝內的東西而不影響外部調用者的代碼;而外部使用用者只知道一個接口(函數),只要接口(函數)名、參數不變,使用者的代碼永遠無需改變。這就提供一個良好的合作基礎——或者說,只要接口這個基礎約定不變,則代碼改變不足為慮。
反射
反射 主要是指程序可以訪問、檢測和修改它本身狀態或行為的一種能力(自?。?
`getattr(object, name, default=None)```:判斷object中有沒有一個name字符串對應的方法或屬性
hasattr(object,'name')?。z測是否含有某屬性
setattr(object,name,True) ?。≡O置屬性\
delattr(object,'name') - 刪除屬性
基于反射- 動態導入模塊
內置屬性方法
getattr , delattr , setattr
getattr
:一個對象在調不存在的屬性時候,就會自動觸發。
delattr : 一個對象刪除類屬性或對象屬性時候,會觸發
setattr
: 在設置屬性或新增屬性時候,默認就會觸發
setattr
,如果在創建類的時候重新定義了
setattr
方法,要寫上操作屬性字典代碼,不寫就增加屬性不成功
利用上述幾個內置方法,可以二次加工標準類型。比如重新定義 setattr ,在新增屬性之前加點自定義參數
包裝一個類型通常是對已存在的類型的一些定制,這種做法可以新建,修改或刪除原有產品的功能。其它的則保持原樣。授權的過程,即是所有更新的功能都是由新類的某部分來處理,但已存在的功能就授權給對象的默認屬性。
實現授權的關鍵點就是覆蓋 getattr 方法
setitem,getitem,delitem 用字典方式調用屬性的時候就會觸發。如:kk['name']
用點(.)方式調用屬性會觸發
getattr
等方法。如:kk.name
str
,
repr
,:改變對象的字符串顯示
str
,
repr
自定制格式化字符串
format
str函數或者print函數--->obj.
str
()
repr或者交互式解釋器--->obj.
repr
()
如果
str
沒有被定義,那么就會使用
repr
來代替輸出
注意:這倆方法的返回值必須是字符串,否則拋出異常
slots
slots 是一個類變量,變量值可以是列表,元祖,或者可迭代對象,也可以是一個字符串(意味著所有實例只有一個數據屬性)
使用點來訪問屬性本質就是在訪問類或者對象的 dict 屬性字典(類的字典是共享的,而每個實例的是獨立的),字典會占用大量內存,如果有一個類,屬性很少,但是實例很多,為了節省內存可以使用 slots 取代實例的 dict 。(可以說是用來作為一個內存優化工具)
定義了 slots 后的類不再 支持一些普通類特性了,比如多繼承
del
析構方法,當對象在內存中被釋放時,自動觸發執行。
注:如果產生的對象僅僅只是python程序級別的(用戶級),那么無需定義 del ,如果產生的對象的同時還會向操作系統發起系統調用,即一個對象有用戶級與內核級兩種資源,比如(打開一個文件,創建一個數據庫鏈接),則必須在清除對象的同時回收系統資源,這就用到了 del
next 和 iter 實現迭代器協議
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
