一、綁定方法(綁定給誰,誰來調用就自動將它自己看成第一個參數傳入python
1)綁定到類的方法:用classmethod裝飾器裝飾的方法。編程
爲類量身定製 類.boud_method(),自動將類看成第一個參數傳入 (其實對象也可調用,但仍將類看成第一個參數傳入)
2)綁定到對象的方法:沒有被任何裝飾器裝飾的方法。函數
爲對象量身定製 對象.boud_method(),自動將對象看成第一個參數傳入 (屬於類的函數,類能夠調用,可是必須按照函數的規則來,沒有自動傳值那麼一說)
二、非綁定方法:用staticmethod裝飾器裝飾的方法工具
不與類或對象綁定,類和對象均可以調用,可是沒有自動傳值那麼一說。就是一個普通工具而已code
注:與綁定到對象方法區分開,在類中直接定義的函數,沒有被任何裝飾器裝飾的,都是綁定到對象的方法,可不是普通函數,對象調用該方法會自動傳值,而staticmethod裝飾的方法,無論誰來調用,都沒有自動傳值一說。對象
綁定給對象的方法(略)md5
綁定給類的方法(classmethod):utf-8
classmehtod是給類用的,即綁定到類,類在使用時會將類自己當作參數傳給類方法的第一個參數(即使是對象來調用也會將類看成第一個參數傳入),python爲咱們內置了函數classmethod來把類中的函數定義成類方法hash
#settings.py HOST='127.0.0.1' PORT=3306 DB_PATH=r'C:\Users\Administrator\PycharmProjects\test\面向對象編程\test1\db' #test.py import settings class MySQL: def __init__(self,host,port): self.host=host self.port=port @classmethod def from_conf(cls): print(cls) return cls(settings.HOST,settings.PORT) print(MySQL.from_conf) #<bound method MySQL.from_conf of <class '__main__.MySQL'>> conn=MySQL.from_conf() conn.from_conf() #對象也能夠調用,可是默認傳的第一個參數仍然是類
在類內部用staticmethod裝飾的函數即非綁定方法,就是普通函數it
statimethod不與類或對象綁定,誰均可以調用,沒有自動傳值效果
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(): #就是一個普通工具 m=hashlib.md5(str(time.time()).encode('utf-8')) return m.hexdigest() print(MySQL.create_id) #<function MySQL.create_id at 0x0000000001E6B9D8> #查看結果爲普通函數 conn=MySQL('127.0.0.1',3306) print(conn.create_id) #<function MySQL.create_id at 0x00000000026FB9D8> #查看結果爲普通函數
class MySQL: def __init__(self,host,port): self.host=host self.port=port @staticmethod def from_conf(): return MySQL(settings.HOST,settings.PORT) # @classmethod #哪一個類來調用,就將哪一個類當作第一個參數傳入 # def from_conf(cls): # return cls(settings.HOST,settings.PORT) def __str__(self): return '就不告訴你' class Mariadb(MySQL): def __str__(self): return '<%s:%s>' %(self.host,self.port) m=Mariadb.from_conf() print(m) #咱們的意圖是想觸發Mariadb.__str__,可是結果觸發了MySQL.__str__的執行,打印就不告訴你: