先看一段代碼:
class T1(threading.Thread):
def __init__(self, a, b, c):
super(T1, self).__init__()
self.a = a
self.b = b
self.c = c
def run(self):
print self.a, self.b, self.c
代碼定義了一個(gè)繼承自threading.Thread的class,看這句
super(T1, self).__init__()
也有些人喜歡這么寫(xiě)
threading.Thread.__init__(self)
當(dāng)然作用都是調(diào)用父類(lèi)的構(gòu)造函數(shù)。
寫(xiě)了這么久的python代碼,每次寫(xiě)到這都有重復(fù)造輪子的感覺(jué)。剛才突然想到裝飾器這個(gè)好東西,試著寫(xiě)了個(gè)autoInitClass來(lái)幫助pythoner脫離苦海,免去手動(dòng)調(diào)用父類(lèi)構(gòu)造函數(shù)的麻煩。
代碼如下:
def autoInitClass(OldClass):
superClass = OldClass.mro()[1]
class NewClass(OldClass):
def __init__(*args):
self = args[0]
superClass.__init__(self)
apply(OldClass.__init__, args)
return NewClass
使用autoInitClass裝飾器構(gòu)造新類(lèi):
@autoInitClass
class T2(threading.Thread):
def __init__(self, a, b, c):
#不用再寫(xiě)super(T2, self).__init__()
self.a = a
self.b = b
self.c = c
def run(self):
print self.a, self.b, self.c
本文來(lái)自: itianda's blog ,轉(zhuǎn)載請(qǐng)注明原文出處
本站僅提供存儲(chǔ)服務(wù),所有內(nèi)容均由用戶(hù)發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)
點(diǎn)擊舉報(bào)。