python繼承

Enoch Liu98發表於2020-10-20

1.繼承,呼叫父類屬性方法

在python裡面,繼承一個類只需要這樣寫:

class Animal:
    def heshui(self):
        print('動物正在喝水')

class Cat(Animal):
    pass

這樣Cat就有了Animal的所有屬性和方法,呼叫的時候直接呼叫就可以了:

#接上面程式碼

cat = Cat()

cat.heshui()


>>>動物正在喝水

這個時候,如果子類想重寫父類的方法,可以直接重寫:

class Animal:
    def heshui(self):
        print('動物正在喝水')

class Cat(Animal):
    def heshui(self):
        print('貓正在喝水')
cat = Cat()
cat.heshui()

>>>貓正在喝水

如果想呼叫父類的 heshui 這個方法,可以用 super() :

class Animal:
    def heshui(self):
        print('動物正在喝水')

class Cat(Animal):
    def heshui(self):
        super().heshui()
cat = Cat()
cat.heshui()

>>>動物正在喝水

2.強制呼叫父類私有屬性方法

如果父類的方法是私有方法,如 def __heshui(self) 這樣的話再去呼叫就提示沒有這個方法,其實編譯器是把這個方法的名字改成了 _Animal__heshui(),如果強制呼叫,可以這樣:

class Animal:
    def __heshui(self):
        print('動物正在喝水')

class Cat(Animal):
    def heshui(self):
        super()._Animal__heshui()

cat = Cat()
cat.heshui()

>>>動物正在喝水

最後,如果自己也定義了 init 方法,那麼父類的屬性是不能直接呼叫的:

class Animal:
    def __init__(self):
        self.a = 'aaa'

class Cat(Animal):
    def __init__(self):
        pass

cat = Cat()
print(cat.a)


>>>AttributeError: 'Cat' object has no attribute 'a'

那麼可以在 子類的 __init__中呼叫一下父類的 init 方法,這樣就可以呼叫了:

class Animal:
    def __init__(self):
        self.a = 'aaa'

class Cat(Animal):
    def __init__(self):
        super().__init__()  #也可以用 Animal.__init__(self)  這裡面的self一定要加上

cat = Cat()
print(cat.a)

>>>aaa

相關文章