Python面向對象編程——基本語法

Python面向對象編程——基本語法

1、類的語法

上一節最後的代碼其實有問題,屬性名字和年齡都寫死了,想傳名字傳不進去。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間接獲取被封裝的內容

瞭解了基本定義,下面詳解下類的方法和屬性

2、類的方法

構造方法

剛纔上面已經說了,主要做用是實例化時給實例一些初始化參數,或執行一些其它的初始化工做,總之,由於這個__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--')
相關文章
相關標籤/搜索