<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    qileilove

    blog已經轉移至github,大家請訪問 http://qaseven.github.io/

    python方法、屬性

    魔法方法、屬性

    ------------------------

     

    準備工作

    為了確保類是新型類,應該把 _metaclass_=type 入到你的模塊的最開始。

    class NewType(Object):   mor_code_here class OldType:   mor_code_here

    在這個兩個類中NewType是新類,OldType是屬于舊類,如果前面加上 _metaclass_=type ,那么兩個類都屬于新類。

     

     

    構造方法

     

    構造方法與其的方法不一樣,當一個對象被創建會立即調用構造方法。創建一個python的構造方法很簡答,只要把init方法,從簡單的init方法,轉換成魔法版本的_init_方法就可以了。

    復制代碼
    class FooBar:     def __init__(self):         self.somevar = 42          >>> f =FooBar() >>> f.somevar 42
    復制代碼

     

     

    重寫一個一般方法

     

    每一個類都可能擁有一個或多個超類(父類),它們從超類那里繼承行為方法。

    復制代碼
    class A:     def hello(self):         print 'hello . I am A.' class B(A):   pass  >>> a = A() >>> b = B() >>> a.hello() hello . I am A.
    復制代碼

    因為B類沒有hello方法,B類繼承了A類,所以會調用A 類的hello方法。

     

    在子類中增加功能功能的最基本的方式就是增加方法。但是也可以重寫一些超類的方法來自定義繼承的行為。如下:

    復制代碼
    class A:     def hello(self):         print 'hello . I am A.' class B(A):     def hello(self):         print 'hello . I am  B'  >>> b = B() >>> b.hello() hello . I am  B
    復制代碼

     

     

    特殊的和構造方法

     

    重寫是繼承機制中的一個重要內容,對一于構造方法尤其重要。看下面的例子:

    復制代碼
    class Bird:     def __init__(self):         self.hungry = True     def eat(self):         if self.hungry:             print 'Aaaah...'             self.hungry = False         else:             print 'No, thanks!'  >>> b = Bird() >>> b.eat() Aaaah... >>> b.eat() No, thanks!
    復制代碼

    這個類中定義了鳥有吃的能力, 當它吃過一次后再次就會不餓了,通過上面的執行結果可以清晰的看到。

    那么用SongBird類來繼承Bird 類,并且給它添加歌唱的方法:

    復制代碼
    class Bird:     def __init__(self):         self.hungry = True     def eat(self):         if self.hungry:             print 'Aaaah...'             self.hungry = False         else:             print 'No, thanks!'               class SongBird(Bird):          def __init__(self):                  self.sound = 'Squawk!'          def sing(self):                  print self.sound  >>> s = SongBird() >>> s.sing() Squawk! >>> s.eat()  Traceback (most recent call last):   File "<pyshell#26>", line 1, in <module>     s.eat()   File "C:/Python27/bird", line 6, in eat     if self.hungry: AttributeError: 'SongBird' object has no attribute 'hungry'
    復制代碼

    異常很清楚地說明了錯誤:SongBird沒有hungry特性。原因是這樣的:在SongBird中,構造方法被重寫,但新的構造方法沒有任何關于初始化hungry特性的代碼。為了達到預期的效果,SongBird的構造方法必須調用其超類Bird的構造方法來確保進行基本的初始化。

    兩種方法實現:

    一 、調用未綁定的超類構造方法

    復制代碼
    class Bird:     def __init__(self):         self.hungry = True     def eat(self):         if self.hungry:             print 'Aaaah...'             self.hungry = False         else:             print 'No, thanks!'               class SongBird(Bird):          def __init__(self):                  Bird.__init__(self)                  self.sound = 'Squawk!'          def sing(self):                  print self.sound   >>> s = SongBird() >>> s.sing() Squawk! >>> s.eat() Aaaah... >>> s.eat() No, thanks!
    復制代碼

    在SongBird類中添加了一行代碼Bird.__init__(self) 。 在調用一個實例的方法時,該方法的self參數會被自動綁定到實例上(這稱為綁定方法)。但如果直接調用類的方法,那么就沒有實例會被綁定。這樣就可以自由地提供需要的self參數(這樣的方法稱為未綁定方法)。

    通過將當前的實例作為self參數提供給未綁定方法,SongBird就能夠使用其超類構造方法的所有實現,也就是說屬性hungry能被設置。

     

    二、使用super函數

    復制代碼
    __metaclass__ = type  #表明為新式類 class Bird:     def __init__(self):         self.hungry = True     def eat(self):         if self.hungry:             print 'Aaaah...'             self.hungry = False         else:             print 'No, thanks!'               class SongBird(Bird):          def __init__(self):                  super(SongBird,self).__init__()                  self.sound = 'Squawk!'          def sing(self):                  print self.sound  >>> s.sing() Squawk! >>> s.eat() Aaaah... >>> s.eat() No, thanks!
    復制代碼

    super函數只能在新式類中使用。當前類和對象可以作為super函數的參數使用,調用函數返回的對象的任何方法都是調用超類的方法,而不是當前類的方法。那就可以不同在SongBird的構造方法中使用Bird,而直接使用super(SongBird,self)

     

     

    屬性

     

    訪問器是一個簡單的方法,它能夠使用getHeight setHeight 之樣的名字來得到或者重綁定一些特性。如果在訪問給定的特性時必須要采取一些行動,那么像這樣的封裝狀態變量就很重要。如下:

    復制代碼
    class Rectangle:     def __init__(self):         self.width = 0         self.height = 0     def setSize(self,size):         self.width , self.height = size     def getSize(self):         return self.width , self.height  >>> r = Rectangle() >>> r.width = 10 >>> r.height = 5 >>> r.getSize() (10, 5) >>> r.setSize((150,100)) >>> r.width 150
    復制代碼

    在上面的例子中,getSizesetSize方法一個名為size的假想特性的訪問器方法,size是由width height構成的元組。

     

     

    property 函數

     

    property函數的使用很簡單,如果已經編寫了一個像上節的Rectangle 那樣的類,那么只要增加一行代碼:

    復制代碼
    __metaclass__ = type class Rectangle:     def __int__(self):         self.width = 0         self.height = 0     def setSize(self,size):         self.width, self.height = size     def getSize(self):         return self.width ,self.height     size = property(getSize ,setSize)   >>> r = Rectangle() >>> r.width = 10 >>> r.height = 5 >>> r.size (10, 5) >>> r.size = 150,100 >>> r.width 150
    復制代碼

    在這個新版的Retangle 中,property 函數創建了一個屬性,其中訪問器函數被用作參數(先取值,然后是賦值),這個屬性命為size 。這樣一來就不再需要擔心是怎么實現的了,可以用同樣的方式處理widthheight size

     

    posted on 2014-02-14 15:45 順其自然EVO 閱讀(195) 評論(0)  編輯  收藏 所屬分類: python

    <2025年5月>
    27282930123
    45678910
    11121314151617
    18192021222324
    25262728293031
    1234567

    導航

    統計

    常用鏈接

    留言簿(55)

    隨筆分類

    隨筆檔案

    文章分類

    文章檔案

    搜索

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 亚洲成在人线中文字幕| 国产成人亚洲综合无| 成人午夜18免费看| 一区二区视频在线免费观看| 亚洲国产精品一区二区久久hs| 黄色片在线免费观看| 一级做受视频免费是看美女| 亚洲精品免费在线| 无码不卡亚洲成?人片| 亚洲欧洲日产国码av系列天堂| 6080午夜一级毛片免费看 | 久久精品国产亚洲AV电影 | 亚洲成AV人片在线观看无| 免费精品国偷自产在线在线| 最好2018中文免费视频| 337p日本欧洲亚洲大胆精品555588 | 免费在线观看中文字幕| 中文字幕一区二区三区免费视频| 久久久无码精品亚洲日韩按摩| 国产午夜无码视频免费网站| 99re视频精品全部免费| 日本高清不卡中文字幕免费| 亚洲一区二区三区在线| 亚洲精品无码午夜福利中文字幕 | 免费一级毛片在线播放不收费| 每天更新的免费av片在线观看| eeuss影院ss奇兵免费com| 激情五月亚洲色图| 久久久久亚洲AV成人无码| 亚洲av日韩片在线观看| 成人免费无码大片a毛片| 99久久人妻精品免费一区| 一级做a爰片久久免费| 亚洲国产精品无码久久久秋霞1| 久久久久久久亚洲Av无码| 久久精品亚洲男人的天堂| 国产免费资源高清小视频在线观看| 午夜国产精品免费观看| 18禁在线无遮挡免费观看网站| 未满十八私人高清免费影院| 亚洲精品无码少妇30P|