Python教程 繫結方法與非繫結方法

2021-10-20 00:19:29 字數 4865 閱讀 3007

一、繫結方法

1.物件的繫結方法

首先我們明確乙個知識點,凡是類中的方法或函式,預設情況下都是繫結給物件使用的。下面,我們通過例項,來慢慢解析繫結方法的應用。

class

people

:def

__init__

(self,name,age)

: self.name = name

self.age = age

deftalk

(self)

:pass

p = people(

'xiaohua',18

)print

(p.talk)

'''輸出結果:

>

'''

從上面的輸出結果來看,talk()這個類的方法,是繫結給物件使用的。下面,我在看看另外一種情況。

class

people

:def

__init__

(self,name,age)

: self.name = name

self.age = age

deftalk()

:pass

p = people(

'xiaohua',18

)print

(p.talk)

'''輸出結果:

>

'''

現在,我們將talk()函式的引數去掉,結果顯示與上面是一樣。

這說明,不管是類中的方法,還是類中函式,預設情況下都是繫結給物件使用的。繫結給物件使用有一種好處,那就是不用手動將物件傳入。物件是自動傳到類中。

'''

'''class

people

:def

__init__

(self,name,age)

: self.name = name

self.age = age

deftalk()

:pass

p = people(

'xiaohua',18

)print

(people.talk)

print

(p.talk)

'''輸出結果:

類來呼叫僅僅是當作函式使用

> 而物件來呼叫則為繫結方法

'''

上面很好說明了,如果類來呼叫類中的方法,那麼這個方法僅僅只是乙個函式,那麼既然是函式,就不會有自動傳值這一功能。

來看看下面**:

class

people

:def

__init__

(self,name,age)

: self.name = name

self.age = age

deftalk

(self)

:pass

p = people(

'xiaohua',18

)people.talk()1

p.talk()2

# **1處報錯

# talk() missing 1 required positional argument: 'self'

# **2處正常

從上面輸出結果來看,當類呼叫類中的方法時候,是不會進行自動傳值的,也就是說,函式有幾個引數,我們就得傳遞進去幾個引數。如果想結果正常執行,那麼在類名呼叫talk()的時候,將引數一一都傳遞進去。即:

people.talk(

312312

)

這個引數可以是任意的,但是,必須傳遞進去。而,當物件呼叫類中方法時候,則不用傳遞,如上面的2正常執行。

'''

'''class

people

:def

__init__

(self,name,age)

: self.name = name

self.age = age

deftalk()

:pass

p = people(

'xiaohua',18

)people.talk()1

p.talk()2

# 1處正常執行

# 2 處報錯

# talk() takes 0 positional arguments but 1 was given

從輸出結果來看,people來呼叫talk()方法時候,並不需要傳遞引數;而當物件來呼叫talk()的時候,由於物件呼叫自己的繫結方法,會自動將物件當作第乙個引數傳遞進去,所以,當類中talk()方法沒有帶引數時,而你又給它傳遞了乙個,顯然是會報錯的。

綜上所述,我們可以得出以下結論:

2.類的繫結方法

既然類中的方法,預設都是繫結給物件使用,那麼,我們要採取一點措施,將類中的繫結方法解除物件繫結關係,進而繫結到類上。

在python中,引入了@classmethod方法,將類中的方法繫結到類身上。下面看看**:

class

people

: @classmethod

deftalk

(cls)

:pass

p = people(

)print

(people.talk)

#輸出結果

# >

從上述結果可以看出,我們加上了乙個裝飾器,將類中繫結給物件的方法,繫結到類身上了。我們之前分析過,如果乙個方法繫結到誰身上,那麼在呼叫該函式的時候,將自動將該呼叫者當作第乙個引數傳遞到函式中。

但是,繫結到類的方法與繫結到物件方法有一點點不同:

class

people

:def

__init__

(self,name)

: self.name = name

@classmethod

deftalk

(cls)

:pass

p = people(

'xiaohua'

)print

(people.talk)

print

(p.talk)

# 輸出結果

# >

# >

也就是說,當物件在呼叫類的繫結方法時,也會預設把類當作引數傳遞進去!所以下面執行正常,並不會因為這個方法繫結到類身上,而物件呼叫沒有傳遞引數,報錯!

'''

'''class

people

: @classmethod

deftalk

(cls)

:pass

p = people(

)people.talk(

)p.talk(

)

但是,如果talk()沒有引數,則下面**均會報錯。

class

people

: @classmethod

deftalk()

:pass

p = people(

)people.talk(

)p.talk(

)# 報錯結果

# talk() takes 0 positional arguments but 1 was given

兩者報錯結果一致,這就說明了,當物件來呼叫類的繫結方法時,也是自動將類傳遞進去,並不需遵循函式引數傳遞的規則。

對於類中的繫結方法,也基本上就這兩種,不管怎麼變化,只要記住以下規則,遇到這種情況,都不會再錯。

類中方法預設都是繫結給物件使用,當物件呼叫繫結方法時,會自動將物件作為第乙個引數傳遞進去;而類來呼叫,則必須遵循函式引數一一對應的規則,有幾個引數,就必須傳遞幾個引數。如果乙個方法是用@classmethod裝飾器,那麼這個方法繫結到類身上,不管是物件來呼叫還是類呼叫,都會將類作為第乙個引數傳遞進去。

二、非繫結方法

上面說了,類中的方法要麼是繫結給物件使用,要麼是繫結給類使用,那麼有沒有不繫結給兩者使用的函式?

python給我們提供了@staticmethod,可以解除繫結關係,將乙個類中的方法,變為乙個普通函式。

下面,我們來看看**示例:

import hashlib

import time

class

mysql

:def

__init__

(self,host,port)

: self.

id=self.create_id(

) self.host=host

self.port=port

@staticmethod

defcreate_id()

:#就是乙個普通工具

m=hashlib.md5(

str(time.clock())

.encode(

'utf-8'))

return m.hexdigest(

)print

(mysql.create_id)

##檢視結果為普通函式

conn=mysql(

'127.0.0.1'

,3306

)print

(conn.create_id)

##檢視結果為普通函式

從上面的輸出結果,我們可以看出,使用了@staticmethod裝飾了乙個函式,那麼這個函式跟普通函式沒有什麼區別。既然是普通函式,那麼就遵從函式引數傳遞規則,有幾個引數就傳遞幾個引數。

繫結方法與非繫結方法

特性 繫結給誰就應該由誰來呼叫,誰來呼叫就會將誰當作第乙個引數自動傳入 精髓在於自動傳值 繫結方法分為兩類 1.1 繫結給物件方法 在類內部定義的函式 沒有被任何裝飾器修飾的 預設就是繫結給物件用的 1.2 繫結給類的方法 在類內部定義的函式如果被裝飾器 classmethod裝飾,那麼則是繫結給類...

python類的繫結方法與非繫結方法

一 繫結方法 首先我們明確乙個知識點,凡是類中的方法或函式,預設情況下都是繫結給物件使用的。下面,我們通過例項,來慢慢解析繫結方法的應用。class people def init self,name,age self.name name self.age age deftalk self pass...

python 物件導向(繫結方法與非繫結方法)

一 繫結方法 繫結給誰就應該由誰來呼叫,誰來呼叫就會將誰當做第乙個引數傳入 1.繫結給物件的方法 類中定義的函式預設就是繫結給物件的 二 非繫結方法 即不與類繫結,又不與物件繫結,意味著物件和類都可以來呼叫,無論誰來呼叫都是乙個普通函式,沒有自動傳值的效果 import settings class...