您好,登錄后才能下訂單哦!
一、綁定方法
1.對(duì)象的綁定方法
首先我們明確一個(gè)知識(shí)點(diǎn),凡是類中的方法或函數(shù),默認(rèn)情況下都是綁定給對(duì)象使用的。下面,我們通過(guò)實(shí)例,來(lái)慢慢解析綁定方法的應(yīng)用。
class People: def __init__(self,name,age): self.name = name self.age = age def talk(self): pass p = People('xiaohua',18) print(p.talk) 輸出結(jié)果: <bound method People.talk of <__main__.People object at 0x000000F802C69358>>
從上面的輸出結(jié)果來(lái)看,talk()這個(gè)類中的方法,是綁定給對(duì)象使用的。下面,我在看看另外一種情況。
class People: def __init__(self,name,age): self.name = name self.age = age def talk(): pass p = People('xiaohua',18) print(p.talk) 輸出結(jié)果: <bound method People.talk of <__main__.People object at 0x000000FF68F39358>>
現(xiàn)在,我們將talk()函數(shù)的參數(shù)去掉,結(jié)果顯示與上面是一樣。這說(shuō)明,不管是類中的方法,還是類中函數(shù),默認(rèn)情況下都是綁定給對(duì)象使用的。綁定給對(duì)象使用有一種好處,那就是不用手動(dòng)將對(duì)象傳入。對(duì)象是自動(dòng)傳到類中。如果你不信,我們來(lái)看看下面的例子:
class People: def __init__(self,name,age): self.name = name self.age = age def talk(): pass p = People('xiaohua',18) print(People.talk) print(p.talk) 輸出結(jié)果: <function People.talk at 0x000000C54E3D0A60> 類來(lái)調(diào)用僅僅是當(dāng)作函數(shù)使用 <bound method People.talk of <__main__.People object at 0x000000C54E249358>> 而對(duì)象來(lái)調(diào)用則為綁定方法
上面很好說(shuō)明了,如果類來(lái)調(diào)用類中的方法,那么這個(gè)方法僅僅只是一個(gè)函數(shù),那么既然是函數(shù),就不會(huì)有自動(dòng)傳值這一功能。來(lái)看看下面代碼:
class People: def __init__(self,name,age): self.name = name self.age = age def talk(self): pass p = People('xiaohua',18) People.talk() 1 p.talk() 2 #代碼1處報(bào)錯(cuò) talk() missing 1 required positional argument: 'self' #代碼2處正常
從上面輸出結(jié)果來(lái)看,當(dāng)類調(diào)用類中的方法時(shí)候i,是不會(huì)進(jìn)行自動(dòng)傳值的,也就是說(shuō),函數(shù)有幾個(gè)參數(shù),我們就得傳遞進(jìn)去幾個(gè)參數(shù)。如果想結(jié)果正常運(yùn)行,那么在類名調(diào)用talk()的時(shí)候,將參數(shù)一一都傳遞進(jìn)去。即:
People.talk(312312)
這個(gè)參數(shù)可以是任意的,但是,必須傳遞進(jìn)去。而,當(dāng)對(duì)象調(diào)用類中方法時(shí)候,則不用傳遞,如上面的2正常執(zhí)行。既然知道了區(qū)別,那么,我們來(lái)看看下面代碼:
class People: def __init__(self,name,age): self.name = name self.age = age def talk(): pass p = People('xiaohua',18) People.talk() 1 p.talk() 2 # 1處正常執(zhí)行 # 2 處報(bào)錯(cuò) talk() takes 0 positional arguments but 1 was given
從輸出結(jié)果來(lái)看,People來(lái)調(diào)用talk()方法時(shí)候,并不需要傳遞參數(shù);而當(dāng)對(duì)象來(lái)調(diào)用talk()的時(shí)候,由于對(duì)象調(diào)用自己的綁定方法,會(huì)自動(dòng)將對(duì)象當(dāng)作第一個(gè)參數(shù)傳遞進(jìn)去,所以,當(dāng)類中talk()方法沒(méi)有帶參數(shù)時(shí),而你又給它傳遞了一個(gè),顯然是會(huì)報(bào)錯(cuò)的。
綜上所述,我們可以得出以下結(jié)論:
1.凡是類中的方法和函數(shù),都是綁定給對(duì)象使用的;
2.綁定方法都有自動(dòng)傳值的功能。傳遞進(jìn)去的值,就是對(duì)象本身。
3.如果類想調(diào)用綁定方法,就必須遵循函數(shù)的參數(shù)規(guī)則,有幾個(gè)參數(shù),就必須傳遞幾個(gè)參數(shù)。
聰明的你,可能會(huì)問(wèn),既然類中的方法都是綁定給對(duì)象使用的,那么有沒(méi)有方法是綁定給類使用的呢?
答案是,當(dāng)然有!
2.類的綁定方法
既然類中的方法,默認(rèn)都是綁定給對(duì)象使用,那么,我們要采取一點(diǎn)措施,將類中的綁定方法解除對(duì)象綁定關(guān)系,進(jìn)而綁定到類上。
在python中,引入了@classmethod方法,將類中的方法綁定到類身上。下面看看代碼:
class People: @classmethod def talk(cls): pass p = People() print(People.talk) #輸出結(jié)果 <bound method People.talk of <class '__main__.People'>>
從上述結(jié)果可以看出,我們加上了一個(gè)裝飾器,將類中綁定給對(duì)象的方法,綁定到類身上了。我們之前分析過(guò),如果一個(gè)方法綁定到誰(shuí)身上,那么在調(diào)用該函數(shù)的時(shí)候,將自動(dòng)將該調(diào)用者當(dāng)作第一個(gè)參數(shù)傳遞到函數(shù)中。但是,綁定到類的方法與綁定到對(duì)象方法有一點(diǎn)點(diǎn)不同:
class People: def __init__(self,name): self.name = name @classmethod def talk(cls): pass p = People('xiaohua') print(People.talk) print(p.talk) #輸出結(jié)果 <bound method People.talk of <class '__main__.People'>> <bound method People.talk of <class '__main__.People'>>
也就是說(shuō),當(dāng)對(duì)象在調(diào)用類的綁定方法時(shí),也會(huì)默認(rèn)把類當(dāng)作參數(shù)傳遞進(jìn)去!所以下面執(zhí)行正常,并不會(huì)因?yàn)檫@個(gè)方法綁定到類身上,而對(duì)象調(diào)用沒(méi)有傳遞參數(shù),報(bào)錯(cuò)!
class People: @classmethod def talk(cls): pass p = People() People.talk() p.talk()
但是,如果talk()沒(méi)有參數(shù),則下面代碼均會(huì)報(bào)錯(cuò)。
class People: @classmethod def talk(): pass p = People() People.talk() p.talk() #報(bào)錯(cuò)結(jié)果 talk() takes 0 positional arguments but 1 was given
兩者報(bào)錯(cuò)結(jié)果一致,這就說(shuō)明了,當(dāng)對(duì)象來(lái)調(diào)用類的綁定方法時(shí),也是自動(dòng)將類傳遞進(jìn)去,并不需遵循函數(shù)參數(shù)傳遞的規(guī)則。
對(duì)于類中的綁定方法,也基本上就這兩種,不管怎么變化,只要記住以下規(guī)則,遇到這種情況,都不會(huì)再錯(cuò)。
類中方法默認(rèn)都是綁定給對(duì)象使用,當(dāng)對(duì)象調(diào)用綁定方法時(shí),會(huì)自動(dòng)將對(duì)象作為第一個(gè)參數(shù)傳遞進(jìn)去;而類來(lái)調(diào)用,則必須遵循函數(shù)參數(shù)一一對(duì)應(yīng)的規(guī)則,有幾個(gè)參數(shù),就必須傳遞幾個(gè)參數(shù)。如果一個(gè)方法是用了@classmethod裝飾器,那么這個(gè)方法綁定到類身上,不管是對(duì)象來(lái)調(diào)用還是類調(diào)用,都會(huì)將類作為第一個(gè)參數(shù)傳遞進(jìn)去。
二、非綁定方法
上面說(shuō)了,類中的方法要么是綁定給對(duì)象使用,要么是綁定給類使用,那么有沒(méi)有不綁定給兩者使用的函數(shù)?
答案:當(dāng)然有,python給我們提供了@staticmethod,可以解除綁定關(guān)系,將一個(gè)類中的方法,變?yōu)橐粋€(gè)普通函數(shù)。
下面,我們來(lái)看看代碼示例:
import hashlib import time class MySQL: def __init__(self,host,port): self.id=self.create_id() self.host=host self.port=port @staticmethod def create_id(): #就是一個(gè)普通工具 m=hashlib.md5(str(time.clock()).encode('utf-8')) return m.hexdigest() print(MySQL.create_id) #<function MySQL.create_id at 0x0000000001E6B9D8> #查看結(jié)果為普通函數(shù) conn=MySQL('127.0.0.1',3306) print(conn.create_id) #<function MySQL.create_id at 0x00000000026FB9D8> #查看結(jié)果為普通函數(shù)
從上面的輸出結(jié)果,我們可以看出,使用了@staticmethod裝飾了一個(gè)函數(shù),那么這個(gè)函數(shù)跟普通函數(shù)沒(méi)有什么區(qū)別。既然是普通函數(shù),那么就遵從函數(shù)參數(shù)傳遞規(guī)則,有幾個(gè)參數(shù)就傳遞幾個(gè)參數(shù)。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。