新聞中心
在 Python 的類體中定義的方法默認(rèn)都是實(shí)例方法,通過對(duì)象來調(diào)用實(shí)例方法。

但要提醒大家的是,Python 的類在很大程度上是一個(gè)命名空間,當(dāng)程序在類體中定義變量、方法時(shí),與前面介紹的定義變量、定義函數(shù)其實(shí)并沒有太大的不同。對(duì)比如下代碼:
# 定義全局空間的foo函數(shù)
def foo ():
print("全局空間的foo方法")
# 全局空間的bar變量
bar = 20
class Bird:
# 定義Bird空間的foo函數(shù)
def foo():
print("Bird空間的foo方法")
# 定義Bird空間的bar變量
bar = 200
# 調(diào)用全局空間的函數(shù)和變量
foo()
print(bar)
# 調(diào)用Bird空間的函數(shù)和變量
Bird.foo()
print(Bird.bar)上面代碼在全局空間和 Bird 類(Bird 空間)中分別定義了 foo() 函數(shù)和 bar 變量,從定義它們的代碼來看,幾乎沒有任何區(qū)別,只是在 Bird 類中定義它們時(shí)需要縮進(jìn)。
接下來程序在調(diào)用 Bird 空間內(nèi)的 bar 變量和 foo() 函數(shù)(方法)時(shí),只要添加 Bird. 前綴即可,這說明完全可以通過 Bird 類來調(diào)用 foo() 函數(shù)(方法)。這就是類調(diào)用實(shí)例方法的證明。
現(xiàn)在問題來了,如果使用類調(diào)用實(shí)例方法,那么該方法的第一個(gè)參數(shù)(self)怎么自動(dòng)綁定呢?例如如下程序:
class User: def walk (self): print(self, '正在慢慢地走') # 通過類調(diào)用實(shí)例方法 User.walk()
運(yùn)行上面代碼,程序會(huì)報(bào)出如下錯(cuò)誤:
TypeError: walk() missing 1 required positional argument:'self'
請(qǐng)看程序最后一行代碼,調(diào)用 walk() 方法缺少傳入的 self 參數(shù),所以導(dǎo)致程序出錯(cuò)。這說明在使用類調(diào)用實(shí)例方法時(shí),Python 不會(huì)自動(dòng)為第一個(gè)參數(shù)綁定調(diào)用者。實(shí)際上也沒法自動(dòng)綁定,因此實(shí)例方法的調(diào)用者是類本身,而不是對(duì)象。
如果程序依然希望使用類來調(diào)用實(shí)例方法,則必須手動(dòng)為方法的第一個(gè)參數(shù)傳入?yún)?shù)值。例如,將上面的粗體字代碼改為如下形式:
u = User() # 顯式為方法的第一個(gè)參數(shù)綁定參數(shù)值 User.walk(u)
此代碼顯式地為 walk() 方法的第一個(gè)參數(shù)綁定了參數(shù)值,這樣的調(diào)用效果完全等同于執(zhí)行 u.walk()。
實(shí)際上,當(dāng)通過 User 類調(diào)用 walk() 實(shí)例方法時(shí),Python 只要求手動(dòng)為第一個(gè)參數(shù)綁定參數(shù)值,并不要求必須綁定 User 對(duì)象,因此也可使用如下代碼進(jìn)行調(diào)用:
# 顯式為方法的第一個(gè)參數(shù)綁定fkit字符串參數(shù)值
User.walk('fkit')如果按上面方式進(jìn)行綁定,那么 'fkit' 字符串就會(huì)被傳給 walk() 方法的第一個(gè)參數(shù) self。因此,運(yùn)行上面代碼,將會(huì)看到如下輸出結(jié)果:
fkit 正在慢慢地走
總結(jié)
Python 的類可以調(diào)用實(shí)例方法,但使用類調(diào)用實(shí)例方法時(shí),Python 不會(huì)自動(dòng)為方法的第一個(gè)參數(shù) self 綁定參數(shù)值;程序必須顯式地為第一個(gè)參數(shù) self 傳入方法調(diào)用者。這種調(diào)用方式被稱為“未綁定方法”。
文章名稱:創(chuàng)新互聯(lián)Python教程:Python類調(diào)用實(shí)例方法
分享鏈接:http://m.5511xx.com/article/dhsiceh.html


咨詢
建站咨詢
