面向物件之繫結方法與非繫結方法
一 類中定義的函式分成兩大類
一:繫結方法(繫結給誰,誰來呼叫就自動將它本身當作第一個引數傳入):
1. 繫結到類的方法:用classmethod裝飾器裝飾的方法。
為類量身定製
類.boud_method(),自動將類當作第一個引數傳入
(其實物件也可呼叫,但仍將類當作第一個引數傳入)
2. 繫結到物件的方法:沒有被任何裝飾器裝飾的方法。
為物件量身定製
物件.boud_method(),自動將物件當作第一個引數傳入
(屬於類的函式,類可以呼叫,但是必須按照函式的規則來,沒有自動傳值那麼一說)
二:非繫結方法:用staticmethod裝飾器裝飾的方法
1. 不與類或物件繫結,類和物件都可以呼叫,但是沒有自動傳值那麼一說。就是一個普通工具而已
注意:與繫結到物件方法區分開,在類中直接定義的函式,沒有被任何裝飾器裝飾的,都是繫結到物件的方法,可不是普通函式,物件呼叫該方法會自動傳值,而staticmethod裝飾的方法,不管誰來呼叫,都沒有自動傳值一說
二 繫結方法
繫結給物件的方法(略)
繫結給類的方法(classmethod)
classmehtod是給類用的,即繫結到類,類在使用時會將類本身當做引數傳給類方法的第一個引數(即便是物件來呼叫也會將類當作第一個引數傳入),python為我們內建了函式classmethod來把類中的函式定義成類方法
HOST='127.0.0.1' PORT=3306 DB_PATH=r'C:\Users\Administrator\PycharmProjects\test\面向物件程式設計\test1\db'settings.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裝飾的函式即非繫結方法,就是普通函式
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> #檢視結果為普通函式
四 classmethod與staticmethod的區別
import settings 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__的執行,列印就不告訴你:mariadb是mysql
五 練習
定義MySQL類
1.物件有id、host、port三個屬性
2.定義工具create_id,在例項化時為每個物件隨機生成id,保證id唯一
3.提供兩種例項化方式,方式一:使用者傳入host和port 方式二:從配置檔案中讀取host和port進行例項化
4.為物件定製方法,save和get_obj_by_id,save能自動將物件序列化到檔案中,檔案路徑為配置檔案中DB_PATH,檔名為id號,儲存之前驗證物件是否已經存在,若存在則丟擲異常,;get_obj_by_id方法用來從檔案中反序列化出物件
原文連結:http://www.cnblogs.com/dkblog/archive/2011/10/10/2205200.html Python官方Doc:《20.15. uuid — UUID objects according to RFC 4122》 UUID的演算法介紹:《A Universally Unique IDentifier (UUID) URN Namespace》 概述: UUID是128位的全域性唯一識別符號,通常由32位元組的字串表示。 它可以保證時間和空間的唯一性,也稱為GUID,全稱為: UUID —— Universally Unique IDentifier Python 中叫 UUID GUID —— Globally Unique IDentifier C# 中叫 GUID 它通過MAC地址、時間戳、名稱空間、隨機數、偽隨機數來保證生成ID的唯一性。 UUID主要有五個演算法,也就是五種方法來實現: 1、uuid1()——基於時間戳 由MAC地址、當前時間戳、隨機數生成。可以保證全球範圍內的唯一性, 但MAC的使用同時帶來安全性問題,區域網中可以使用IP來代替MAC。 2、uuid2()——基於分散式計算環境DCE(Python中沒有這個函式) 演算法與uuid1相同,不同的是把時間戳的前4位置換為POSIX的UID。 實際中很少用到該方法。 3、uuid3()——基於名字的MD5雜湊值 通過計算名字和名稱空間的MD5雜湊值得到,保證了同一名稱空間中不同名字的唯一性, 和不同名稱空間的唯一性,但同一名稱空間的同一名字生成相同的uuid。 4、uuid4()——基於隨機數 由偽隨機數得到,有一定的重複概率,該概率可以計算出來。 5、uuid5()——基於名字的SHA-1雜湊值 演算法與uuid3相同,不同的是使用 Secure Hash Algorithm 1 演算法 使用方面: 首先,Python中沒有基於DCE的,所以uuid2可以忽略; 其次,uuid4存在概率性重複,由無對映性,最好不用; 再次,若在Global的分散式計算環境下,最好用uuid1; 最後,若有名字的唯一性要求,最好用uuid3或uuid5。 編碼方法: # -*- coding: utf-8 -*- import uuid name = "test_name" namespace = "test_namespace" print uuid.uuid1() # 帶參的方法參見Python Doc print uuid.uuid3(namespace, name) print uuid.uuid4() print uuid.uuid5(namespace, name)建立唯一id之UUID
#settings.py內容 ''' HOST='127.0.0.1' PORT=3306 DB_PATH=r'E:\CMS\aaa\db' ''' import settings import uuid import pickle import os class MySQL: def __init__(self,host,port): self.id=self.create_id() self.host=host self.port=port def save(self): if not self.is_exists: raise PermissionError('物件已存在') file_path=r'%s%s%s' %(settings.DB_PATH,os.sep,self.id) pickle.dump(self,open(file_path,'wb')) @property def is_exists(self): tag=True files=os.listdir(settings.DB_PATH) for file in files: file_abspath=r'%s%s%s' %(settings.DB_PATH,os.sep,file) obj=pickle.load(open(file_abspath,'rb')) if self.host == obj.host and self.port == obj.port: tag=False break return tag @staticmethod def get_obj_by_id(id): file_abspath = r'%s%s%s' % (settings.DB_PATH, os.sep, id) return pickle.load(open(file_abspath,'rb')) @staticmethod def create_id(): return str(uuid.uuid1()) @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.save() conn1=MySQL('127.0.0.1',3306) conn1.save() #丟擲異常PermissionError: 物件已存在 obj=MySQL.get_obj_by_id('7e6c5ec0-7e9f-11e7-9acc-408d5c2f84ca') print(obj.host)View Code
其他練習
class Date: def __init__(self,year,month,day): self.year=year self.month=month self.day=day @staticmethod def now(): #用Date.now()的形式去產生例項,該例項用的是當前時間 t=time.localtime() #獲取結構化的時間格式 return Date(t.tm_year,t.tm_mon,t.tm_mday) #新建例項並且返回 @staticmethod def tomorrow():#用Date.tomorrow()的形式去產生例項,該例項用的是明天的時間 t=time.localtime(time.time()+86400) return Date(t.tm_year,t.tm_mon,t.tm_mday) a=Date('1987',11,27) #自己定義時間 b=Date.now() #採用當前時間 c=Date.tomorrow() #採用明天的時間 print(a.year,a.month,a.day) print(b.year,b.month,b.day) print(c.year,c.month,c.day) #分割線============================== import time class Date: def __init__(self,year,month,day): self.year=year self.month=month self.day=day @staticmethod def now(): t=time.localtime() return Date(t.tm_year,t.tm_mon,t.tm_mday) class EuroDate(Date): def __str__(self): return 'year:%s month:%s day:%s' %(self.year,self.month,self.day) e=EuroDate.now() print(e) #我們的意圖是想觸發EuroDate.__str__,但是結果為 ''' 輸出結果: <__main__.Date object at 0x1013f9d68> ''' 因為e就是用Date類產生的,所以根本不會觸發EuroDate.__str__,解決方法就是用classmethod import time class Date: def __init__(self,year,month,day): self.year=year self.month=month self.day=day # @staticmethod # def now(): # t=time.localtime() # return Date(t.tm_year,t.tm_mon,t.tm_mday) @classmethod #改成類方法 def now(cls): t=time.localtime() return cls(t.tm_year,t.tm_mon,t.tm_mday) #哪個類來呼叫,即用哪個類cls來例項化 class EuroDate(Date): def __str__(self): return 'year:%s month:%s day:%s' %(self.year,self.month,self.day) e=EuroDate.now() print(e) #我們的意圖是想觸發EuroDate.__str__,此時e就是由EuroDate產生的,所以會如我們所願 ''' 輸出結果: year:2017 month:3 day:3 '''View Code
相關推薦
python面向物件程式設計之封裝-繫結方法與非繫結方法
1.繫結方法 特性:繫結給誰就應該由誰來呼叫,誰來呼叫就會將誰當做第一個引數自動傳入 (精髓在於自動傳入) 繫結方法分為兩類: 1.繫結給物件方法 在類內部定義的函式(沒有被任何封裝器修飾的),預設就是繫結給物件用的
面向物件之繫結方法與非繫結方法
一 類中定義的函式分成兩大類 一:繫結方法(繫結給誰,誰來呼叫就自動將它本身當作第一個引數傳入): 1. 繫結到類的方法:用classmethod裝飾器裝飾的方法。 為類量身定製 類.boud_method(),自動將類當作第一個
1.面向過程程式設計 2.面向物件程式設計 3.類和物件 4.python 建立類和物件 如何使用物件 5.屬性的查詢順序 6.初始化函式 7.繫結方法 與非繫結方法
1.面向過程程式設計 面向過程:一種程式設計思想在編寫程式碼時 要時刻想著過程這個兩個字過程指的是什麼? 解決問題的步驟 流程,即第一步幹什麼 第二步幹什麼,其目的是將一個複雜的問題,拆分為若干的小的問題,按照步驟一一解決,也可以說 將一個複雜的問題,流程化(為其制定一個固定的實現流程),從而變得簡單化例如
面向物件 8 繫結方法與非繫結方法
介紹 ''' 在類內部定義的函式,分為兩大類 一:繫結方法 :繫結給誰,就應該由誰來呼叫,誰來呼叫就會把呼叫者當作第一個引數自動傳入 繫結到物件的方法:在類內定義的沒有被任何裝飾器修飾的 繫結到類的方法:在類內定義的沒有被裝飾器classme
面向物件&網路程式設計 繫結方法與非繫結方法介紹
'''在函式內部定義說的函式分為兩大類: 1:繫結方法 繫結給誰, 就應該由誰來呼叫,誰來呼叫就會把誰當做第一個引數傳入 1:繫結到物件 在類內定義沒有被任何裝飾器修飾的 2:繫結到類 在類內定義的被裝飾器classmethod修飾的方法或者函式 2:非繫結方法
面對物件-繫結方法與非繫結方法
在類內部定義的函式,分為兩大類:一:繫結方法:繫結給誰,就應該由誰來呼叫,誰來呼叫就會把呼叫者當做第一個引數自動傳入 繫結到物件的方法:在類內定義的沒有被任何裝飾器來修飾的 邦定到類的方法:在類內定義的被裝飾器classmethod修飾的方法二:非繫結方法:沒有自動傳值一說了,就是類中的普通工具
面向對象之綁定方法與非綁定方法
obj aps path md5 字符串 _id isp self prop 閱讀目錄 一 類中定義的函數分成兩大類 二 綁定方法 三 非綁定方法 四 classmethod與staticmethod的區別 五 練習 一 類中定義的函數分成兩大類 一:綁定方法
三 面向對象之綁定方法與非綁定方法
init 結果 定義 技術 rmp src pycha pre pytho 一 綁定方法 二 非綁定方法 三 classmethod和staticmethod的區別 一 綁定方法 綁定方法(綁定給誰,誰來調用就自動將它本身當作第一個參數傳入): 1.
Python-類的繫結方法與非繫結方法
類中定義的函式分成兩大類 一:繫結方法(繫結給誰,誰來呼叫就自動將它本身當作第一個引數傳入): 繫結到類的方法:用classmethod裝飾器裝飾的方法。 為類量身定製 類.boud_method(),自動將類當作第一個引數傳入 (其實物件也可呼叫,但仍將類當作第一個
面向對象——綁定方法與非綁定方法
方法 cti tin 就會 close 效果 lap alt method 1 在類內部定義的函數,分為兩大類 2 一:綁定方法:綁定給誰,就應該由誰來調用,誰來調用就會把調用者當做第一個參數自動傳入 3 綁定到對象的方法:在類內定義的沒有被任何裝飾器修飾的 4
【Java】之static靜態方法與非static靜態方法區別
span get nbsp ati pub public ring spa 靜態方法 1、A.class:沒有static public class A { public String getText(){ } B.class調用A的方法
python3 多態,綁定方法與非綁定方法
int 調用 工具 stat sof round 類的方法 nim 抽象 多態:同一種事物的不同形態(一個抽象類有多個子類,因而多態的概念依賴於繼承) 1. 序列類型有多種形態:字符串,列表,元組。 2. 動物有多種形態:人,狗,豬 多態性:多態性是指具有不同功能的
3.1.9 類內部定義的函數:綁定方法與非綁定方法
說明 第一個 ini 對象 assm 說了 In true @class ‘‘‘在類內部定義的函數,分為兩大類: 一:綁定方法:綁定給誰,就應該由誰來調用,誰來調用就會把調用者當作第一個參數自動傳入 1. 綁定到對象的方法:在類內定義的沒有被任何
Python 綁定方法與非綁定方法
第一個 span 基於 ssm 計算 bound 例子 0.10 代碼 用到的: import uuid -------------- uuid是128位的全局唯一標識符, 通常用32位的一個字符串的形式來表現 uuid.uuid1() ---------
綁定方法與非綁定方法的應用介紹
tin eth icm setting hashlib time fun 一個 ssm import settingimport hashlibimport timeclass People: def __init__(self, name, age, sex):
009---綁定方法與非綁定方法
sel env urn ron () odi tel object init 綁定方法和非綁定方法 綁定方法(綁定給誰,誰來調用就自動將它本身作為第一個參數傳進去) 綁定給類:沒有加任何裝飾器的方法,其實對象也可以調用。只不過內部將類作為第一個參數傳進去。 綁定給對象:加
C語言編程 遞歸方法與非遞歸方法 實現將參數字符串中的字符反向排列
%s png images while char s proc 意義 strlen process //題目要求要求:不能使用C函數庫中的字符串操作函數(否則本題也沒什麽意義了啊) <1>非遞歸方法此方法基本思想是設立兩個指針,分別指向字符串的頭尾並且依次交換所
面向物件之(非)繫結方法,反射,isinstance與issubclass
isinstance(obj,cls)和issubclass(sub,super) isinstance(obj,cls)檢查是否obj是否是類 cls 的物件 class Foo(object): pass obj = Foo() isinstance(obj, Foo)
面向物件之定製物件獨有屬性+屬性查詢+繫結方法列印day20
1、為物件定製獨有特徵__init__ 物件的本質就是一個名稱空間而已,物件名稱空間是用來存放物件自己獨有的名字/屬性,而類中存放的是物件共有的屬性 呼叫時發生兩件事: a、建立一個空物件stu1 b、自動觸發類中__init__功能執行,將stu1以及呼叫類括號中的引數一同傳入
python學習之-繫結方法和非繫結方法
繫結方法 @classmethod 函式功能上面新增這個內建函式就是繫結給類 繫結給類的,引數裡面就是cls,cls這個是規範的寫法,cls就是指傳入的是類 特殊之處: 繫結給誰就應該由誰來呼叫,會將呼叫者(點左邊的就是呼叫者)當做第一個引數自動傳入 繫結物件的方法: 類中定義的函式在沒有