上一節最後的代碼其實有問題,屬性名字和年齡都寫死了,想傳名字傳不進去。python
class Person(object): def __init__(self, name, age): self.name = name self.age = age p = Person("Alex", 22) print(p.name, p.age)
爲何有__init__? 爲何有self? 此時的你一臉蒙逼,相信不畫個圖,你的智商是理解不了的!編程
畫圖以前, 你先註釋掉這兩句this
# p = Person("Alex", 22) # print(p.name, p.age) #加上句 print(Person)
#執行結果 <class '__main__.Person'>
這表明什麼?表明 即便不實例化,這個Person類自己也是已經存在內存裏的對不對, yes, cool,那實例化時,會產生什麼化學反應呢?code
其實self,就是實例自己!你實例化時python解釋器會自動把這個實例自己經過self參數傳進去。對象
你說好吧,僞裝懂了,可是這麼幹有什麼好處呢?想了解self的好處,得給Person類加個功能內存
class Person(object): def __init__(self, name, age): self.name = name self.age = age def talk(self): print("Hello, my name is %s, I'm %s years old!" % (self.name, self.age)) p = Person("Alex", 22) # print(p.name, p.age) p.talk() #注意這裏調用並未傳遞參數
執行輸出it
Hello, my name is Alex, I'm 22 years old!
爲什麼p.talk()未傳參數不報錯,且爲什麼talk方法定義要跟一個self參數?面向對象編程
咱們上面講到self實際上是實例自己, 那p.talk() 其實至關於p.talk(p),你不須要本身把p實例傳進去,解釋器幫你幹了,那爲什麼要在talk定義時加self參數呢?class
是由於,你的talk方法裏有調用到實例的屬性呀,這些屬性又都是綁定在實例上的,你想調用實例屬性,就必需要把實例傳進去。object
構造方法:
__init__(...)
被稱爲 構造方法或初始化方法,在例實例化過程當中自動執行,目的是初始化實例的一些屬性。每一個實例經過__init__
初始化的屬性都是獨有的
剛纔定義的這個類體現了面向對象的第一個基本特性,封裝,其實就是使用構造方法將內容封裝到某個具體對象中,而後經過對象直接或者self間接獲取被封裝的內容
瞭解了基本定義,下面詳解下類的方法和屬性
構造方法
剛纔上面已經說了,主要做用是實例化時給實例一些初始化參數,或執行一些其它的初始化工做,總之,由於這個__init__
只要一實例化,就會自動執行,so無論你在這個方法裏寫什麼,它都會通通在實例化時執行一遍。
普通方法
定義類的一些正常功能,好比人這個類, 能夠說話、走路、吃飯等,每一個方法其實想當於一個功能或動做
析構方法(解構方法)
實例在內存中被刪除時,會自動執行這個方法,如你在內存裏生成了一我的的實例,如今他被打死了,那這我的除了本身的實例要被刪除外,可能它在實例外產生的一些痕跡也要清除掉,清除的動做就能夠寫在這個方法裏。
class Person(object): def __init__(self, name, age): self.name = name self.age = age def talk(self): print("Hello, my name is %s, I'm %s years old!" % (self.name, self.age)) def __del__(self): print("running del method, this person must be died.") p = Person("Alex", 22) p.talk() del p print('--end program--')