1. 程式人生 > >面向對象編程(實例屬性、類屬性)

面向對象編程(實例屬性、類屬性)

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
測試通過!

面向對象編程(實例屬性、類屬性)