您好,登錄后才能下訂單哦!
這篇文章主要介紹python編寫定義類的方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
類的定義
Python中,定義類是通過class關鍵字,例如我們定義一個存儲學生信息的類:
class Student(object): pass
class后面緊接著是類名,即Student,類名通常是大寫開頭的單詞,緊接著是(object),表示該類是從哪個類繼承下來的。通常,如果沒有合適的繼承類,就使用object類,這是所有類最終都會繼承的類。
定義好了Student類,就可以根據Student類創建出Student的實例,創建實例是通過類名+()實現的:
>>> bart = Student() >>> bart <__main__.Student object at 0x10a67a590> >>> Student <class '__main__.Student'>
可以看到,變量bart指向的就是一個Student的實例,后面的0x10a67a590是內存地址,每個object的地址都不一樣,而Student本身則是一個類。
可以自由地給一個實例變量綁定屬性,比如,給實例bart綁定一個name屬性:
>>> bart.name = 'Bart Simpson' >>> bart.name 'Bart Simpson'
這點與靜態語言,比如C++是不一樣的。我們可以隨時給一個對象添加屬性。
在python中,類的屬性就等同于c++類的成員變量,類的方法等同于c++類的成員函數。
由于類可以起到模板的作用,因此,可以在創建實例的時候,把一些我們認為必須綁定的屬性強制填寫進去。通過定義一個特殊的init方法,在創建實例的時候,就把name,score等屬性綁上去:
class Student(object): def __init__(self, name, score): self.name = name self.score = score
對比c++,__init__函數就等同于c++類得構造函數,注意:特殊方法“init”前后有兩個下劃線。
注意到init方法的第一個參數永遠是self,表示創建的實例本身,因此,在init方法內部,就可以把各種屬性綁定到self,因為self就指向創建的實例本身。
有了init方法,在創建實例的時候,就不能傳入空的參數了,必須傳入與init方法匹配的參數,但self不需要傳,Python解釋器自己會把實例變量傳進去:
>>> bart = Student('Bart Simpson', 59) >>> bart.name 'Bart Simpson' >>> bart.score 59
和普通的函數相比,在類中定義的函數只有一點不同,就是第一個參數永遠是實例變量self,并且,調用時,不用傳遞該參數。除此之外,類的方法和普通函數沒有什么區別,所以,你仍然可以用默認參數、可變參數、關鍵字參數和命名關鍵字參數。
我們可以給我們定義的Student類增加新的方法,比如get_grade:
class Student(object): ... def get_grade(self): if self.score >= 90: return 'A' elif self.score >= 60: return 'B' else: return 'C'
知識點擴展:
構建和初始化
相信大家都熟悉這個最基礎的神奇方法 __ init__。它令你能自定義一個對象的初始化行為。而當我調用x=SomeClass() 時,__ init__ 并不是最先被調用的。實際上有一個叫做 __ new__ 的方法,事實上是它創建了實例,它傳遞任何參數給初始化程序來達到創建的目的。在對象生命周期結束時,調用 __ del__。讓我們更近地觀察下這 3 個神奇方法吧:
__ new__(cls,[...)
一個對象的實例化時 __ new__ 是第一個被調用的方法。在類中傳遞其他任何參數到 __ init__。__new__很少被使用,這樣做確實有其目的,特別是當一個子類繼承一個不可改變的類型(一個元組或一個字符串)時。我不打算再繼續深入追求 __ new __ 的細節了,因為這不會產生多大用處,因為在 Python Docs 內已經涵蓋了一份巨詳細的說明了。
__ init__(self,[...)
類的初始化。它會獲得初始構建調用傳過來的任何東西(舉例來說就是,當我們調用x=SomeClass(10,'foo'),__ init__ 就會把傳過來的 10 和 'foo' 作為參數。__init__在 Python 的類定義中幾乎普遍被使用)
__ del__(self)
如果 __ new__和 __ init__ 是對象的構造器,那么 __ del__ 就是析構器。它不實現聲明為del x(這樣的代碼不會解釋成 x.__ del__())的行為。相反,它定義為當一個對象被垃圾回收時的行為。這可能對可能需要額外清理的對象相當有用,比如 sockets 或文件對象。但要小心,如果對象仍處于存活狀態而當被解釋退出時,__ del__ 沒有保證就會被執行,因此這樣的__ del__ 不能作為良好的編碼規范的替代。(就像當你完成操作總是要關閉一次連接。但事實上,__ del__ 幾乎永遠不會執行,就因為它處于不安全情況被調用了。使用時保持警惕!)
以上是python編寫定義類的方法的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。