面向對象編程(實例屬性、類屬性)
阿新 • • 發佈:2018-04-28
else 統計學 顯示 刪除 self. 優先級 style 統計 IT
由於Python是動態語言,根據類創建的實例可以任意綁定屬性。
給實例綁定屬性的方法是通過實例變量,或者通過self
變量:
class Student(object): def __init__(self, name): self.name = name s = Student(‘Bob‘) s.score = 90
但是,如果Student
類本身需要綁定一個屬性呢?可以直接在class中定義屬性,這種屬性是類屬性,歸Student
類所有:
class Student(object): name = ‘Student‘
當我們定義了一個類屬性後,這個屬性雖然歸類所有,但類的所有實例都可以訪問到。來測試一下:
>>> class Student(object): ... name = ‘Student‘ ... >>> s = Student() # 創建實例s >>> print(s.name) # 打印name屬性,因為實例並沒有name屬性,所以會繼續查找class的name屬性 Student >>> print(Student.name) # 打印類的name屬性 Student >>> s.name = ‘Michael‘ # 給實例綁定name屬性 >>> print(s.name) # 由於實例屬性優先級比類屬性高,因此,它會屏蔽掉類的name屬性 Michael >>> print(Student.name) # 但是類屬性並未消失,用Student.name仍然可以訪問 Student >>> del s.name # 如果刪除實例的name屬性 >>> print(s.name) # 再次調用s.name,由於實例的name屬性沒有找到,類的name屬性就顯示出來了 Student
從上面的例子可以看出,在編寫程序的時候,千萬不要對實例屬性和類屬性使用相同的名字,因為相同名稱的實例屬性將屏蔽掉類屬性,但是當你刪除實例屬性後,再使用相同的名稱,訪問到的將是類屬性。
練習
為了統計學生人數,可以給Student類增加一個類屬性,每創建一個實例,該屬性自動增加:
class Student(object): count = 0 def __init__(self, name): self.name = name # 測試: if Student.count != 0: print(‘測試失敗!‘) else: bart = Student(‘Bart‘) if Student.count != 1: print(‘測試失敗!‘) else: lisa = Student(‘Bart‘) if Student.count != 2: print(‘測試失敗!‘) else: print(‘Students:‘, Student.count) print(‘測試通過!‘)
答案
class Student(object): count = 0 def __init__(self, name): self.name = name Student.count +=1 # 測試: if Student.count != 0: print(‘測試失敗!‘) else: bart = Student(‘Bart1‘) if Student.count != 1: print(Student.count) print(‘測試失敗!!‘) else: lisa = Student(‘Bart2‘) if Student.count != 2: print(Student.count) print(‘測試失敗!!!‘) else: print(‘Students:‘, Student.count) print(‘測試通過!‘) #輸出 Students: 2 測試通過!
面向對象編程(實例屬性、類屬性)