python内置函数面向对象_Pyhton——面向对象进阶二:类的内置函数补充、描述符...
Pyhton——面向?qū)ο筮M(jìn)階二:
一、類的內(nèi)置函數(shù)補(bǔ)充
1、isinstance(obj,cls)——檢查obj是否是該類的對象
class Hoo:
def __init__(self,name,tem):
self.name = name
self.tem = tem
class foo(Hoo):
pass
f1=foo('e',20)
print(isinstance(f1,Hoo))
首先 f1 肯定是 foo 的對象,如果 Hoo 是 foo 的父類,那么 f1 也同樣是 Hoo 的對象。
2、issubclass(sub,super)——檢查sub類是否是super類的派生類(子類)
3、__getattribute __
首先 __getattribute __ 與前面的 __getattr __ 很像,當(dāng)然他們實(shí)際的功能也類似:
可以看到,當(dāng)執(zhí)行不存在的方法時(shí),應(yīng)該是執(zhí)行 __getattr __ 的,但是現(xiàn)在執(zhí)行的卻是 __getattribute __ ;接著我們看下,如果執(zhí)行的是存在的方法呢?
可以看到,當(dāng)執(zhí)行的方法是存在的時(shí)候,依然執(zhí)行的是 __getattribute __ 。所以,無論執(zhí)行的方法存不存在,都會執(zhí)行 __getattribute __ 。
那么這個(gè)方法有什么作用呢?跟__getattr __ 又有什么聯(lián)系呢?首先先來看下,當(dāng)執(zhí)行一個(gè)不存在的方法時(shí),其報(bào)錯(cuò)的異常
這是原本的異常。
在__getattribute __方法中,可以通過 raise AttributeError 來發(fā)出你想要發(fā)出的異常
如果此時(shí) __getattribute __ 與 __getattr __ 同時(shí)存在會發(fā)生什么呢?
從以上結(jié)果可以看到,當(dāng)這兩個(gè)方法同時(shí)存在,且執(zhí)行類里面沒有的方法時(shí),是不會發(fā)出異常的,本該出現(xiàn)的異常被 __getattr __接去了,
4、__setitem __ 、__getitem __ 與 __delitem __
這三個(gè)與前面的 attr 函數(shù)很類似,功能也差不多。直接上結(jié)論。
attr 函數(shù)主要是通過 點(diǎn) 的方式觸發(fā),當(dāng)通過 點(diǎn) 來調(diào)用方法時(shí),就會觸發(fā) attr 函數(shù)。而 item 函數(shù)主要是通過字典來觸發(fā),當(dāng)用字典來操作的時(shí)候,就會觸發(fā) item 函數(shù)
從上面的結(jié)果可以印證上面的結(jié)論
如果要完成本來的功能,看下:
def __setitem__(self, key, value):
self.__dict__[key] = value
def __getitem__(self, item):
return self.__dict__[item]
def __delitem__(self, key):
self.__dict__.pop(key)
5(1)、__str __ ——打印顯示方式
f1 是類的實(shí)例化對象,直接打印這個(gè)對象,會顯示這么一串東西。如果我們想要顯示別的行不行?
修改此 str 就可以顯示自己要顯示的東西
5(2)、__repr __ ——打印顯示方式
可以看到這里 repr 也能顯示自定義打印方式
同樣是打印顯示方式,str 與 repr 有什么區(qū)別呢?
repr 主要在解釋器中觸發(fā)
那么 repr 與 str 同時(shí)存在會打印哪個(gè)?
兩個(gè)同時(shí)存在的情況下,調(diào)用的是 str ,但并不是優(yōu)先執(zhí)行誰,而是 print 本質(zhì)調(diào)用的是 str方法,如果 找不到 str ,就會去找 repr 這個(gè)替代品
注意:str 與 repr 返回值必須是字符串,否則會拋出異常
6、自定制 format 方法
方法:略
主要通過運(yùn)用字典的方式來自定制
7、slots 屬性
用法舉例:
此方法用得少,用的時(shí)候慎用
8、__doc __ ——文檔描述信息
該屬性無法被繼承
9、__module __和__class __ ——查看對象來自于哪一個(gè)模塊或類
10、__del __ ——析構(gòu)方法
結(jié)論:從上面三個(gè)結(jié)果中看出,只有實(shí)例被刪除的時(shí)候才會觸發(fā) __del __ ;單單刪除實(shí)例下的屬性不會觸發(fā);文件執(zhí)行完畢,實(shí)例被回收,觸發(fā)__del __。
11、__call __
foo 雖然是一個(gè)類,但是也是一個(gè)對象(既然是對象,就有另外一個(gè)類來產(chǎn)生)
12(1)、__iter __ 與 __next __ ——迭代器協(xié)議
其它的暫略… …
12(2)、迭代器協(xié)議實(shí)現(xiàn)斐波那契數(shù)列
二、描述符(__get __、__set __、__delete __)
普通開發(fā)中用不到,開發(fā)大型的框架,給別人用的時(shí)候才用得到
1、描述符的定義
2、描述符的作用
描述符的作用:是用來代理另外一個(gè)類的屬性(必須把描述符定義成這個(gè)類的類屬性,不能定義到構(gòu)造函數(shù)中)
從上圖中看到,無論怎么調(diào)用,都無法觸發(fā)里面的方法,問題在于,描述符是代理另外一個(gè)類的屬性,所以,必須要其他的類來調(diào)用,才能觸發(fā)。看下圖:
上圖中看到,必須是有其他的類來調(diào)用描述符,才能觸發(fā)描述符方法
3、兩種描述符
描述符分兩種
注意事項(xiàng):
一、描述符本身應(yīng)該定義成新式類,被代理的類也應(yīng)該是新式類
二、必須把描述符定義成這個(gè)類的類屬性,不能定義為構(gòu)造函數(shù)中
比如上圖這個(gè),定義成這種就不行,什么都不會觸發(fā)。再看下圖:
這種是可以觸發(fā)的。在上圖 類hoo 當(dāng)中,x被 foo 描述了,所以凡是關(guān)于 x 的操作都是 foo的操作 ;x被 foo 代理了。
三、要嚴(yán)格遵循該優(yōu)先級,優(yōu)先級由高到低分別是:
1.類屬性
2.數(shù)據(jù)描述符
3.實(shí)例屬性
4.非數(shù)據(jù)描述符
5.找不到的屬性觸發(fā)__getattr__()
原文鏈接:https://blog.csdn.net/qq_41824825/article/details/111641808
總結(jié)
以上是生活随笔為你收集整理的python内置函数面向对象_Pyhton——面向对象进阶二:类的内置函数补充、描述符...的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: navicat运行db文件_使用 YAM
- 下一篇: 简述python程序的运行原理_谈谈 P