婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 淺談Python類的單繼承相關知識

淺談Python類的單繼承相關知識

熱門標簽:白銀外呼系統 騰訊外呼線路 陜西金融外呼系統 激戰2地圖標注 海南400電話如何申請 哈爾濱ai外呼系統定制 廣告地圖標注app 公司電話機器人 唐山智能外呼系統一般多少錢

上文我們總結過了Python多繼承的相關知識,沒看過的小伙伴們也可以去看看,今天給大家介紹Python類的單繼承相關知識。

一、類的繼承

面向對象三要素之一,繼承Inheritance

人類和貓類都繼承自動物類。

個體繼承自父母,繼承了父母的一部分特征,但也可以有自己的個性。

在面向對象的世界中,從父類繼承,就可以直接擁有父類的屬性和方法,這樣就可以減少代碼、多服用。子類可以定義自己的屬性和方法

class Animal:
 
    def __init__(self,name):
        self._name = name
 
    def shout(self):
        print("{}  shouts".format(self.__class__.__name__))
    @property
    def name(self):
        return self._name
 
 
class Cat(Animal):
    pass
 
 
class Dog(Animal):
    pass
 
a = Animal("monster")
a.shout()           #   Animal  shouts
 
 
cat = Cat("garfield")
cat.shout()         #   Cat  shouts
print(cat.name)     #   garfield
 
 
dog = Dog("ahuang")
dog.shout()         #   Dog  shouts
print(dog.name)     #   ahuang

上例中我們可以看出,通過繼承、貓類、狗類不用寫代碼,直接繼承了父類的屬性和方法

繼承:

  • class Cat(Animal)這種形式就是從父類繼承,括號中寫上繼承的類的列表。
  • 繼承可以讓子類重父類獲取特征(屬性、方法)

父類:

  • Animal就是Cat的父類,也稱為基類、超類

子類:

  • Cat 就是Animal的子類,也成為派生類  

二、繼承的定義、查看繼承的特殊屬性和方法

格式

class 子類 (基類1[,基類2,……]):
    語句塊

如果類定義時,沒有基類列表,等同于繼承自【object】。在Python3中,【object】類是所有對象基類

查看繼承的特殊屬性和方法

特殊屬性  含義 示例
__base__  類的基類 
__bases__  類的基類元組 
__mro__  顯示方法查找順序,基類的元組 
mro()  同上  int.mro()
__subclasses__()  類的子類列表  int.__subclasses__()

三、繼承中的訪問控制

class Animal:
    __COUNT = 100
    HEIGHT = 0
 
    def __init__(self,age,weight,height):
        self.__COUNT += 1
        self.age = age
        self.__weight = weight
        self.HEIGHT = height
 
    def eat(self):
        print("{}  eat".format(self.__class__.__name__))
 
    def __getweight(self):
        print(self.__weight)
 
    @classmethod
    def showcount1(cls):
        print(cls.__COUNT)
 
    @classmethod
    def __showcount2(cls):
        print(cls.__COUNT)
 
    def showcount3(self):
        print(self.__COUNT)
 
class Cat(Animal):
    NAME = "CAT"
    __COUNT = 200
 
#a = Cat()              #   TypeError: __init__() missing 3 required positional arguments: 'age', 'weight', and 'height'
a = Cat(30,50,15)
a.eat()                 #   Cat  eat
print(a.HEIGHT)         #   15
#print(a.__COUNT)        #   AttributeError: 'Cat' object has no attribute '__COUNT'
#print(a.__showcount2)   #   AttributeError: 'Cat' object has no attribute '__showcount2'
#print(a.__getweight)    #   AttributeError: 'Cat' object has no attribute '__getweight'
a.showcount3()   #   101
a.showcount1()   #  100
print(a.NAME)    #    CAT
 
print(Animal.__dict__)  #   {'__module__': '__main__', '_Animal__COUNT': 100, 'HEIGHT': 0, '__init__': function Animal.__init__ at 0x020DC228>, 'eat': function Animal.eat at 0x020DC468>, '_Animal__getweight': function Animal.__getweight at 0x02126150>, 'showcount1': classmethod object at 0x020E1BD0>, '_Animal__showcount2': classmethod object at 0x020E1890>, 'showcount3': function Animal.showcount3 at 0x021264F8>, '__dict__': attribute '__dict__' of 'Animal' objects>, '__weakref__': attribute '__weakref__' of 'Animal' objects>, '__doc__': None}
print(Cat.__dict__)     #   {'__module__': '__main__', 'NAME': 'CAT', '_Cat__COUNT': 200, '__doc__': None}
print(a.__dict__)       #   {'_Animal__COUNT': 101, 'age': 30, '_Animal__weight': 50, 'HEIGHT': 15}

從父類繼承、自己沒有的,就可以到父類中找

私有的都是不可訪問的,但是本質上依然是改了名稱放在這個屬性所在的類的了【__dict__】中,知道這個新民成就可以了直接找到這個隱藏的變量,這是個黑魔法慎用

總結

  • 繼承時,共有的,子類和實例都可以隨意訪問;私有成員被隱藏,子類和實例不可直接訪問,當私有變量所在類內方法中可以訪問這個私有變量
  • Python通過自己一套實現,實現和其他語言一樣的面向對象的繼承機制

屬性查找順序:實例的【__dict__】------類的【__dict__】-----父類【__dict__】

如果搜索這些地方后沒有找到異常,先找到就立即返回

四、方法的重寫、覆蓋override

class Animal:
 
    def shout(self):
        print("Animal shouts")
 
class Cat(Animal):
 
    def shout(self):
        print("miao")
 
a = Animal()
a.shout()       #   Animal shouts
b  = Cat()
b.shout()       #   miao
 
print(a.__dict__)       #   {}
print(b.__dict__)       #   {}
print(Animal.__dict__)  #   {'__module__': '__main__', 'shout': function Animal.shout at 0x017BC228>, '__dict__': attribute '__dict__' of 'Animal' objects>, '__weakref__': attribute '__weakref__' of 'Animal' objects>, '__doc__': None}

Cat類中shout為什么沒有打印Animal中shout的方法,方法被覆蓋了?

  • 這是因為,屬性查找順序:實例的【__dict__】------類的【__dict__】-----父類【__dict__】

那子類如何打印父類的同命的方法

  • super()可以訪問到父類的屬性
class Animal:
 
    def shout(self):
        print("Animal shouts")
 
class Cat(Animal):
 
    def shout(self):
        print("miao")
 
    def shout(self):
        print("super():   " , super())
        print(super(Cat, self))
        super().shout()
        super(Cat,self).shout()   # 等價于super().shout()
        self.__class__.__base__.shout(self)  #不推薦使用
 
a = Animal()
a.shout()       #   Animal shouts
b  = Cat()
b.shout()       #   super():    super: class 'Cat'>, Cat object>>
                #   super: class 'Cat'>, Cat object>>
                #   Animal shouts
                #   Animal shouts
                #   Animal shouts
print(a.__dict__)       #   {}
print(b.__dict__)       #   {}
print(Animal.__dict__)  #   {'__module__': '__main__', 'shout': function Animal.shout at 0x019AC228>, '__dict__': attribute '__dict__' of 'Animal' objects>, '__weakref__': attribute '__weakref__' of 'Animal' objects>, '__doc__': None}
print(Cat.__dict__)     #   {'__module__': '__main__', 'shout': function Cat.shout at 0x019F6150>, '__doc__': None}
 

super(Cat,self).shout()的作用相當于

  • 調用,當前b的實例中找cat類基類中,shout的方法

那對于類方法和靜態方法是否也同樣適用尼?

class Animal:
    @classmethod
    def class_method(cls):
        print("class_method")
 
    @staticmethod
    def static_method():
        print("static_methond_animal")
 
class Cat(Animal):
    @classmethod
    def class_method(cls):
        super().class_method()  #   class_method
        print("class_method_cat")
 
    @staticmethod
    def static_method(cls,self):
        super(Cat,self).static_method()
        print("static_method_cat")
 
b = Cat()
b.class_method()    #   class_method
                    #   class_method_cat
b.static_method(Cat,b)
                    #   static_methond_animal
                    #   static_method_cat

這些方法都可以覆蓋,原理都一樣,屬性字典的搜索順序

五、繼承中的初始化

看以下一段代碼,有沒有問題

class A:
    def __init__(self,a):
        self.a = a
 
class B(A):
    def __init__(self,b,c):
        self.b = b
        self.c = c
 
    def printv(self):
        print(self.b)
        print(self.a)
 
a = B(100,300)
print(a.__dict__)       #   {'b': 100, 'c': 300}
print(a.__class__.__bases__)    #   (class '__main__.A'>,)
a.printv()      #   100
                #   AttributeError: 'B' object has no attribute 'a'

上例代碼

  • 如果B類定義時聲明繼承自類A,則在B類中__bases__中是可以看到類A
  • 這和是否調用類A的構造方法是兩回事
  • 如果B中調用了A的構造方法,就可以擁有父類的屬性了,如果理解這一句話?
class A:
    def __init__(self,a):
        self.a = a
 
class B(A):
    def __init__(self,b,c):
        super().__init__(b+c)
        # A.__init__(self,b+c)
        self.b = b
        self.c = c
 
    def printv(self):
        print(self.b)
        print(self.a)
 
a = B(100,300)
print(a.__dict__)       #   {'a': 400, 'b': 100, 'c': 300}
print(a.__class__.__bases__)    #   (class '__main__.A'>,)
a.printv()      #   100
                #   400

作為好的習慣,如果父類定義了__init__方法,你就改在子類__init__中調用它【建議適用super()方法調用】

那子類什么時候自動調用父類的【__init__】方法?

例子一:【B實例的初始化會自動調用基類A的__init__方法】

class A:
    def __init__(self):
        self.a1 = "a1"
        self.__a2 = "a2"
        print("A init")
 
class B(A):
    pass
 
b = B()     #   A init
print(b.__dict__)   #   {'a1': 'a1', '_A__a2': 'a2'}

例子二:【B實例的初始化__init__方法不會自動調用父類的初始化__init__方法,需要手動調用】

class A:
    def __init__(self):
        self.a1 = "a1"
        self.__a2 = "a2"
        print("A init")
 
class B(A):
    def __init__(self):
        self.b1 = "b1"
        self.__b2 = "b2"
        print("b init")
        #A.__init__(self)
 
b = B()     #   b init
print(b.__dict__)   #   {'b1': 'b1', '_B__b2': 'b2'}

那如何正確實例化?

  • 注意,調用父類的__init__方法,出現在不同的位置,可能導致出現不同的結果
class Animal:
    def __init__(self,age):
        print("Animal init")
        self.age = age
 
    def show(self):
        print(self.age)
 
class Cat(Animal):
    def __init__(self,age,weight):
        #調用父類的__init__方法的順序 決定show方法的結果
        super(Cat, self).__init__(age)
        print("Cat init")
        self.age = age + 1
        self.weight = weight
 
a = Cat(10,5)
a.show()        #   Animal init
                #   Cat init
                #   11

怎么直接將上例中所有的實例屬性改變為私有屬性?

  • 解決辦法,一個原則,自己的私有屬性,就該自己的方法讀取和修改,不要借助其他類的方法,即父類或者派生類
class Animal:
    def __init__(self,age):
        print("Animal init")
        self.__age = age
 
    def show(self):
        print(self.__age)
 
class Cat(Animal):
    def __init__(self,age,weight):
        #調用父類的__init__方法的順序 決定show方法的結果
        super(Cat, self).__init__(age)
        print("Cat init")
        self.__age = age + 1
        self.__weight = weight
 
    def show(self):
        print(self.__age)
 
a = Cat(10,5)
a.show()        #   Animal init
                #   Cat init
                #   11
print(a.__dict__)   #   {'_Animal__age': 10, '_Cat__age': 11, '_Cat__weight': 5}

到此這篇關于淺談Python類的單繼承相關知識的文章就介紹到這了,更多相關Python類的單繼承內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 詳細總結Python類的多繼承知識
  • python類的繼承鏈實例分析
  • python子類如何繼承父類的實例變量
  • Python類成員繼承重寫的實現
  • Python類繼承和多態原理解析
  • Python 繼承,重寫,super()調用父類方法操作示例
  • python3中類的繼承以及self和super的區別詳解
  • Python3.5面向對象程序設計之類的繼承和多態詳解
  • Python面向對象程序設計類的封裝與繼承用法示例
  • Python基礎知識學習之類的繼承

標簽:常德 黔西 黑龍江 益陽 鷹潭 上海 惠州 四川

巨人網絡通訊聲明:本文標題《淺談Python類的單繼承相關知識》,本文關鍵詞  淺談,Python,類,的,單繼承,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《淺談Python類的單繼承相關知識》相關的同類信息!
  • 本頁收集關于淺談Python類的單繼承相關知識的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美影院精品一区| 久久免费的精品国产v∧| 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 久久精品99国产国产精| 亚洲国产精品欧美一二99| 亚洲女同一区二区| 亚洲欧美在线高清| 自拍偷拍亚洲欧美日韩| 亚洲精品第1页| 久久99国产精品免费| 捆绑紧缚一区二区三区视频 | 国产大片一区二区| 国产成人aaaa| 欧美中文字幕一区二区三区 | 制服视频三区第一页精品| 欧美不卡激情三级在线观看| 久久久亚洲高清| 国产激情91久久精品导航| 精品粉嫩aⅴ一区二区三区四区| 国产精品美女视频| 亚洲美女视频在线观看| 色哟哟亚洲精品| 久久久噜噜噜久久中文字幕色伊伊| 激情综合亚洲精品| 日本一区二区三区四区| 亚洲一线二线三线视频| 国产成人h网站| 亚洲精品福利视频网站| 欧美日本国产视频| 欧美激情在线看| 人人狠狠综合久久亚洲| 成人手机电影网| 日韩三级高清在线| 亚洲成av人片一区二区梦乃 | www.成人网.com| 久久亚洲一区二区三区四区| 粉嫩在线一区二区三区视频| 亚洲一区精品在线| 日韩欧美卡一卡二| 亚洲国产日韩a在线播放| 精品乱人伦小说| 在线观看免费一区| 丁香激情综合国产| 日韩av高清在线观看| 欧美日韩国产精品成人| 国产黑丝在线一区二区三区| 亚洲午夜在线观看视频在线| 欧美mv日韩mv| 亚洲狠狠爱一区二区三区| 久久亚区不卡日本| 欧美国产欧美综合| 欧美美女直播网站| 一区二区三区四区在线播放| 97精品国产露脸对白| 国产亚洲欧美色| 奇米精品一区二区三区在线观看 | 韩国精品久久久| 久久网站最新地址| 欧美日本韩国一区二区三区视频| av在线不卡电影| 国产精品亚洲一区二区三区在线| 国产网站一区二区三区| 91精品国产综合久久精品| 亚洲韩国一区二区三区| 欧美激情一区在线| 亚洲精品一线二线三线无人区| 欧美私模裸体表演在线观看| 成人国产视频在线观看| 日韩欧美精品在线视频| 国产成人综合亚洲网站| 美女免费视频一区| 欧美色网站导航| 91丨九色丨国产丨porny| 亚洲一区二区精品视频| 国产精品私人自拍| 国产日韩欧美激情| 国产无遮挡一区二区三区毛片日本| 国产亚洲欧洲997久久综合 | 欧洲一区二区av| 欧美亚洲一区二区三区四区| 欧美羞羞免费网站| 欧洲av在线精品| 色老综合老女人久久久| 免费在线成人网| 麻豆精品在线看| 国内国产精品久久| 成人免费高清在线| 91香蕉视频mp4| 色综合av在线| 色综合天天做天天爱| 免费成人结看片| 久久精品99国产国产精| 久久精品999| 成人成人成人在线视频| 91国产免费看| 91精品久久久久久久99蜜桃 | 欧美中文一区二区三区| 9191成人精品久久| 久久美女艺术照精彩视频福利播放 | 国产欧美日韩在线| 亚洲色图欧美在线| 午夜久久久久久久久久一区二区| 成人欧美一区二区三区在线播放| 中文字幕亚洲在| 午夜婷婷国产麻豆精品| 国产呦萝稀缺另类资源| 奇米888四色在线精品| 久久er精品视频| 国产成人在线色| 欧美日韩精品免费观看视频| 国产精品日产欧美久久久久| 三级精品在线观看| 亚洲一区二区成人在线观看| 国产呦萝稀缺另类资源| 欧美精品日韩一本| 亚洲色大成网站www久久九九| 蜜臀国产一区二区三区在线播放| 色婷婷综合五月| 欧美高清在线精品一区| 久久福利资源站| 日韩欧美一二区| 偷拍日韩校园综合在线| 91污片在线观看| 亚洲国产精品ⅴa在线观看| 美女在线观看视频一区二区| 欧美丰满美乳xxx高潮www| 一区二区高清视频在线观看| 91亚洲精品久久久蜜桃| 国产人伦精品一区二区| 免费高清成人在线| 日韩欧美一区中文| 蜜臀精品久久久久久蜜臀| 欧美日韩国产精选| 午夜一区二区三区视频| 色av成人天堂桃色av| 国产精品毛片高清在线完整版| 日韩视频123| 麻豆极品一区二区三区| 欧美日韩激情一区| 亚洲视频在线观看一区| 91小视频在线免费看| 国产精品蜜臀在线观看| 91社区在线播放| 亚洲国产欧美一区二区三区丁香婷| 91蜜桃网址入口| 国产精品久久久久久亚洲毛片| 国产精品成人午夜| 天天综合日日夜夜精品| 国产91精品一区二区| 91麻豆精品国产无毒不卡在线观看| 亚洲日本在线观看| 免费高清在线视频一区·| 欧美乱妇20p| 欧美一区二区三区成人| 久久国产精品99精品国产| 欧美精品一区二区在线观看| 亚洲乱码中文字幕| 欧美怡红院视频| 精品电影一区二区三区| 春色校园综合激情亚洲| 欧美年轻男男videosbes| 麻豆精品在线看| 日本一区免费视频| 亚洲一区免费在线观看| 欧洲中文字幕精品| 欧美一级高清大全免费观看| 国产福利91精品| 在线视频你懂得一区二区三区| 日韩av一区二| 亚洲一区中文在线| 一区二区三区四区在线| 精品国产成人在线影院| 国产精品久久久久毛片软件| 欧美在线综合视频| 日韩久久精品一区| 97国产精品videossex| 日韩av在线免费观看不卡| 99v久久综合狠狠综合久久| 午夜精品久久久久久久久久| 中文字幕国产一区二区| 久久99久久99| 香蕉加勒比综合久久| 色综合久久久久久久久久久| 国产在线精品免费av| 91精品国产入口| 91精品1区2区| 国产伦精品一区二区三区免费迷| 在线视频国内一区二区| 丁香六月久久综合狠狠色| 精品福利一二区| 精品久久一区二区三区| 日本不卡123| 亚洲成av人影院在线观看网| 中文字幕一区二区在线播放| 国产精品一区久久久久| 美腿丝袜一区二区三区| 制服丝袜激情欧洲亚洲| 欧美精品99久久久**| 6080yy午夜一二三区久久| 欧美无砖砖区免费|