類是一種數據結構,我們可以用它來定義對象,后者把數據值和行為特性融合在一起。#類是現實世界的抽象的實體以編程形式出現。實例是這些對象的具體化。## 2.1 創建類#類的定義:#class ClassName(object):# 'class documentation string' #類文檔字符串# class_suite #類體##當你創建一個類,你就實際創建了一個你自己的數據類型。盡管類是對象,但正被定義時,它們還不是對象的實現。##類允許派生。你可以創建一個子類,它也是類,而且繼續了父類所有的特征和屬性。從Python2.2 開始,你也可以從內建類型中派生子類,而不是僅僅從其它類。##注意類的參數,object 是“所有類之母”。如果你的類沒有繼承任何其他父類,object 將作為默認的父類。它位于所有類繼承結構的最上層。#基類是一個或多個用于繼承的父類的集合
;類體由所有聲明語句,類成員定義,數據屬性和函數組成。#類通常在一個模塊的頂層進行定義,以便類實例能夠在類所定義的源代碼文件中的任何地方被創建.## 2.2 聲明與定義#對于Python 函數來說,聲明與定義類沒什么區別,因為他們是同時進行的,定義(類體)緊跟#在聲明(含class 關鍵字的頭行[header line])和可選(但總是推薦使用)的文檔字符串后面。同時,#所有的方法也必須同時被定義。如果對OOP 很熟悉,請注意Python 并不支持純虛函數(像C++)或#者抽象方法(如在JAVA 中),這些都強制程序員在子類中定義方法。作為替代方法,你可以簡單地#在基類方法中引發NotImplementedError 異常,這樣可以獲得類似的效果。#*********** Part 3: 類屬性 ***********************#屬性就是屬于另一個對象的數據或者函數元素,可以通過我們熟悉的句點屬性#標識法來訪問。一些Python 類型比如復數有數據屬性(實部和虛部),而另外一些,像列表和字典,擁有方法(函數屬性)。#有關屬性的一個有趣的地方是,當你正訪問一個屬性時,它同時也是一個對象,擁有它自己的#屬性,可以訪問,這導致了一個屬性鏈,比如,myThing,subThing,subSubThing.等等。常見例子如下:# sys.stdout.write('foo')# print myModule.myClass.__doc__# myList.extend(map(upper, open('x').readlines()))## 3.1 類的數據屬性#數據屬性僅僅是所定義的類的變量。它們可以像任何其它變量一樣在類創建后被使用,并且,#要么是由類中的方法來更新,要么是在主程序其它什么地方被更新。即靜態變量,或者是靜態數據。它們表示這些數據是與它們所#屬的類對象綁定的,不依賴于任何類實例。#靜態成員通常僅用來跟蹤與類相關的值。大多數情況下,你會考慮用實例屬性,而不是類屬性。#class c1(object):# num=100##c2=c1()#print(c2.num)##-->100#c2.num+=1#print(c2.num)#-->101 ## 3.2 方法#方法,即類中的函數#class c1(object):# name='dave'# def showName(self,name):# print('name is:',name)##c2=c1()#c2.showName('DMM')#-->#name is: DMM#注意self 參數,它在所有的方法聲明中都存在。這個參數代表實例對象本身,當你#用實例調用方法時,由解釋器悄悄地傳遞給方法的,所以,你不需要自己傳遞self 進來,因為它是#自動傳入的。舉例說明一下,假如你有一個帶兩參數的方法,所有你的調用只需要傳遞第二個參數,Python 把self 作為第一個參數傳遞進來######### 綁定(綁定及非綁定方法)#為與OOP 慣例保持一致,Python 嚴格要求,沒有實例,方法是不能被調用的。這種限制即Python所描述的綁定概念(binding),#在此,方法必須綁定(到一個實例)才能直接被調用。非綁定的
方法可能可以被調用,但實例對象一定要明確給出,才能確保調用成功。#然而,不管是否綁定,方法都是它所在的類的固有屬性,即使它們幾乎總是通過實例來調用的.## 3.3 決定類的屬性#要知道一個類有哪些屬性,有兩種方法。最簡單的是使用dir()內建函數。另外是通過訪問類的字典屬性__dict__,這是所有類都具備的特殊屬性之一。#class c1(object):# name='dave'# def showName(self,name):# print('name is:',name)#print(dir(c1))#-->#['__class__', '__delattr__', '__dict__', '__doc__', '__eq__', '__format__', '__ge__', #'__getattribute__', '__gt__', '__hash__', '__init__', '__le__', '__lt__', '__module__', #'__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', #'__str__', '__subclasshook__', '__weakref__', 'name', 'showName']#注意dir 返回的是列表#print(c1.__dict__)#-->#{'__module__': '__main__', 'name': 'dave', '__dict__': , #'__weakref__': , '__doc__': None, #'showName': }#注意__dict__ 返回的是字典## 3.4 特殊的類屬性#C.__name__ 類C的名字(字符串)#C.__doc__ 類C的文檔字符串#C.__bases__ 類C的所有父類構成的元組#C.__dict__ 類C的屬性#C.__module__ 類C定義所在的模塊(1.5 版本新增)#C.__class__ 實例C對應的類(僅新式類中)#class c1(object):# def showName(self,name):# print('name is:',name)##class c2(object):# 'This is the name'# def showName(self,name):# print('name is:',name) #__name__是給定類的字符名字。它適用于那種只需要字符串(類對象的名字),而非類對象本身#的情況。甚至一些內建的類型也有這個屬性,我們將會用到其中之一來展示__name__字符串的益處。#__doc__是類的文檔字符串,與函數及模塊的文檔字符串相似,必須緊隨頭行(header line)#后的字符串。文檔字符串不能被派生類繼承,也就是說派生類必須含有它們自己的文檔字符串。#c3=c1()#c4=c2()#print(c3.__doc__)#print(c4.__doc__)#-->#None #c1 類我們沒有定義文檔字符串,所以顯示為None#This is the name#Python 支持模塊間的類繼承