您好,登錄后才能下訂單哦!
這篇文章主要介紹了Python裝飾器與線程結(jié)合如何提高接口訪問(wèn)效率,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
裝飾器的本質(zhì)是閉包,是python的一種語(yǔ)法糖
def outer(fun): def inner(*args,**kwargs): return fun(*args,**kwargs) return inner # 使用裝飾器裝飾一下兩個(gè)函數(shù) @outer def num1(): print('a') @outer def num2(): print('b') if __name__ == '__main__': print(num1.__name__) print(num2.__name__) 以上代碼輸出結(jié)果: inner inner 裝飾器的特性:使用自定義的裝飾器會(huì)改變被裝飾函數(shù)的函數(shù)名,一般裝飾器器是不用考慮這一點(diǎn)的,但是如果多個(gè)函數(shù)被兩個(gè)裝飾器裝飾就會(huì)報(bào)錯(cuò),因?yàn)楹瘮?shù)名一樣
解決辦法:引入 functools.wraps
import functools def outer(fun): @functools.wraps(fun) def inner(*args,**kwargs): return fun(*args,**kwargs) return inner
以上代碼輸出結(jié)果:
num1
num2
定義多線程的裝飾器
def async_call(fun): def wrapper(*args, **kwargs): Thread(target=fun, args=args, kwargs=kwargs).start() return wrapper
可以在需要提升效率的接口上添加該裝飾器
因?yàn)檎?lái)說(shuō)線程的執(zhí)行效率要比進(jìn)程快
可以用裝飾器測(cè)試并統(tǒng)計(jì)函數(shù)運(yùn)行時(shí)間
import time def coast_time(func): def fun(*args, **kwargs): t = time.perf_counter() result = func(*args, **kwargs) print(f'func {func.__name__} coast time:{time.perf_counter() - t:.8f} s') return result return fun
這個(gè)裝飾器有感興趣的朋友可以保存起來(lái),以后測(cè)接口性能可以直接拿過(guò)來(lái)用!
from time import sleep from time import time import time from threading import Thread #這是統(tǒng)計(jì)時(shí)間的裝飾器 def coast_time(func): def fun(*args, **kwargs): t = time.perf_counter() result = func(*args, **kwargs) print(f'func {func.__name__} coast time:{time.perf_counter() - t:.8f} s') return result return fun #這是創(chuàng)建線程的裝飾器,感興趣的可以保存一下,可以直接使用的 def async_call(fun): def wrapper(*args, **kwargs): Thread(target=fun, args=args, kwargs=kwargs).start() return wrapper @coast_time @async_call def hello(): print('start') sleep(2) print('end') return if __name__ == "__main__": hello()
不創(chuàng)建線程的運(yùn)行時(shí)間是:2s多
使用線程裝飾器的時(shí)間:0.0003s
可以在引入functools.wraps,防止裝飾多個(gè)函數(shù)的時(shí)候,函數(shù)名被改變
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“Python裝飾器與線程結(jié)合如何提高接口訪問(wèn)效率”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。