先看一段代碼:
複製代碼 代碼如下: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
代碼定義了一個繼承自threading.Thread的class,看這句
super(T1, self).__init__()
也有些人喜歡這麼寫
threading.Thread.__init__(self)
當然作用都是調用父類的建構函式。
寫了這麼久的python代碼,每次寫到這都有重複造輪子的感覺。剛才突然想到裝飾器這個好東西,試著寫了個autoInitClass來協助pythoner脫離苦海,免去手動調用父類建構函式的麻煩。
代碼如下: 複製代碼 代碼如下: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裝飾器構造新類:
複製代碼 代碼如下:@autoInitClass
class T2(threading.Thread):
def __init__(self, a, b, c):
#不用再寫super(T2, self).__init__()
self.a = a
self.b = b
self.c = c
def run(self):
print self.a, self.b, self.c
本文來自: itianda's blog ,轉載請註明原文出處