python继承——封装
python繼承——封裝
?
1 為什么要封裝
封裝數據的主要原因是:保護隱私?
封裝方法的主要原因是:隔離復雜度
?
2?封裝分為兩個層面
第一個層面的封裝(什么都不用做):創建類和對象會分別創建二者的名稱空間,我們只能用類名.或者obj.的方式去訪問里面的名字,這本身就是一種封裝
>>> r1.nickname '草叢倫' >>> Riven.camp 'Noxus'注意:對于這一層面的封裝(隱藏),類名.和實例名.就是訪問隱藏屬性的接口
?
第二個層面的封裝:類中把某些屬性和方法隱藏起來(或者說定義成私有的),只在類的內部使用、外部無法訪問,或者留下少量接口(函數)供外部訪問。
在python中用雙下劃線的方式實現隱藏屬性(設置成私有的)
類中所有雙下劃線開頭的名稱如__x都會自動變形成:_類名__x的形式:
class A:__N=0 #類的數據屬性就應該是共享的,但是語法上是可以把類的數據屬性設置成私有的如__N,會變形為_A__Ndef __init__(self):self.__X=10 #變形為self._A__Xdef __foo(self): #變形為_A__fooprint('from A')def bar(self):self.__foo() #只有在類內部才可以通過__foo的形式訪問到.這種自動變形的特點:
1.類中定義的__x只能在內部使用,如self.__x,引用的就是變形的結果。
2.這種變形其實正是針對外部的變形,在外部是無法通過__x這個名字訪問到的。
2.在子類定義的__x不會覆蓋在父類定義的__x,因為子類中變形成了:_子類名__x,而父類中變形成了:_父類名__x,即雙下滑線開頭的屬性在繼承給子類時,子類是無法覆蓋的。
注意:對于這一層面的封裝(隱藏),我們需要在類中定義一個函數(接口函數)在它內部訪問被隱藏的屬性,然后外部就可以使用了
?
這種變形需要注意的問題是:
1.這種機制也并沒有真正意義上限制我們從外部直接訪問屬性,知道了類名和屬性名就可以拼出名字:_類名__屬性,然后就可以訪問了,如a._A__N
>>> a=A() >>> a._A__N 0 >>> a._A__X 10 >>> A._A__N 02.變形的過程只在類的定義是發生一次,在定義后的賦值操作,不會變形
3.在繼承中,父類如果不想讓子類覆蓋自己的方法,可以將方法定義為私有的
#正常情況 >>> class A: ... def fa(self): ... print('from A') ... def test(self): ... self.fa() ... >>> class B(A): ... def fa(self): ... print('from B') ... >>> b=B() >>> b.test() from B#把fa定義成私有的,即__fa >>> class A: ... def __fa(self): #在定義時就變形為_A__fa ... print('from A') ... def test(self): ... self.__fa() #只會與自己所在的類為準,即調用_A__fa ... >>> class B(A): ... def __fa(self): ... print('from B') ... >>> b=B() >>> b.test() from A
?
轉載于:https://www.cnblogs.com/niejinmei/p/6768368.html
總結
以上是生活随笔為你收集整理的python继承——封装的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: linux中vim常用命令总结
- 下一篇: 霍金:AI或许能根除疾病和贫穷,但也可能