日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

python 裝飾器詳解

系統(tǒng) 1706 0

1、python裝飾器

?

?

最基礎(chǔ)的函數(shù)

            1 def sum1():
2      sum = 1 + 2
3      print(sum)
4 sum1()
          

查看函數(shù)執(zhí)行用了多長(zhǎng)時(shí)間,寫了幾句代碼插進(jìn)去了:

復(fù)制代碼

             1 import time
 2 
 3 def sum1():
 4     start = time.clock()
 5     sum = 1+2
 6     print(sum)
 7     end = time.clock()
 8     print("time used:",end - start)
 9 
10 sum1()
          

復(fù)制代碼

?

可是隨著繼續(xù)翻看,對(duì)越來越多的函數(shù)感興趣了,都想看下他們的運(yùn)行時(shí)間如何,難道要一個(gè)一個(gè)的去改函數(shù)嗎?當(dāng)然不是!我們可以考慮重新定義一個(gè)函數(shù)timeit,將sum1的引用傳遞給他,然后在timeit中調(diào)用sum1并進(jìn)行計(jì)時(shí),這樣,我們就達(dá)到了不改動(dòng)sum1定義的目的,而且,不論看了多少個(gè)函數(shù),我們都不用去修改函數(shù)定義了!

復(fù)制代碼

            import time

def sum1():
    sum = 1+ 2
    print (sum)

def timeit(func):
    start = time.clock()
    func()
    end =time.clock()
    print("time used:", end - start)

timeit(sum1)
          

復(fù)制代碼

咂一看,沒啥問題,可以運(yùn)行!但是還是修改了一部分代碼,把sum1() 改成了timeit(sum1)。這樣的話,如果sum1在N處都被調(diào)用了,你就不得不去修改這N處的代碼。所以,我們就需要楊sum1()具有和timeit(sum1)一樣的效果,于是將timeit賦值給sum1。可是timeit是有參數(shù)的,所以需要找個(gè)方法去統(tǒng)一參數(shù),將timeit(sum1)的返回值(計(jì)算運(yùn)行時(shí)間的函數(shù))賦值給sum1。

復(fù)制代碼

             1 import time
 2 
 3 def sum1():
 4     sum = 1+ 2
 5     print (sum)
 6 
 7 def timeit(func):
 8     def test():
 9         start = time.clock()
10         func()
11         end =time.clock()
12         print("time used:", end - start)
13     return test
14 
15 sum1 = timeit(sum1)
16 sum1()
          

復(fù)制代碼

這樣一個(gè)簡(jiǎn)易的裝飾器就做好了,我們只需要在定義sum1以后調(diào)用sum1之前,加上sum1= timeit(sum1),就可以達(dá)到計(jì)時(shí)的目的,這也就是裝飾器的概念,看起來像是sum1被timeit裝飾了!Python于是提供了一個(gè)語法糖來降低字符輸入量。

復(fù)制代碼

             1 import time
 2   
 3 def timeit(func):
 4      def test():
 5          start = time.clock()
 6          func()
 7          end =time.clock()
 8          print("time used:", end - start)
 9      return test
10  
11 @timeit
12 def sum1():
13      sum = 1+ 2
14      print (sum)
15 
16  sum1()
          

復(fù)制代碼

重點(diǎn)關(guān)注第11行的@timeit,在定義上加上這一行與另外寫sum1 = timeit(sum1)完全等價(jià)。


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 嵊泗县| 桃园县| 游戏| 吉林省| 龙山县| 凯里市| 大名县| 饶阳县| 临泽县| 丘北县| 施秉县| 新建县| 巴马| 绥阳县| 梅河口市| 灯塔市| 元阳县| 玛曲县| 吉安县| 精河县| 萍乡市| 柘荣县| 叶城县| 珲春市| 道真| 万荣县| 上饶市| 南岸区| 正宁县| 融水| 门源| 巧家县| 石城县| 康保县| 缙云县| 岗巴县| 平昌县| 新津县| 海南省| 郯城县| 安顺市|