Python裝飾器與線程結(jié)合提高接口訪問(wèn)效率方法
回顧裝飾器的基本用法
裝飾器的本質(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
實(shí)際業(yè)務(wù)中的應(yīng)用
定義多線程的裝飾器
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ù)名被改變
以上就是Python裝飾器與線程結(jié)合提高接口訪問(wèn)效率方法的詳細(xì)內(nèi)容,更多關(guān)于Python提高接口訪問(wèn)效率的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
如何用Python?實(shí)現(xiàn)景區(qū)安防系統(tǒng)
本設(shè)計(jì)中,利用YOLO目標(biāo)檢測(cè)算法、Openpose姿態(tài)識(shí)別算法、deepsort跟蹤算法、MSCNN人群密度估計(jì)算法實(shí)現(xiàn)了火災(zāi)監(jiān)測(cè)、吸煙監(jiān)測(cè)、行為安全監(jiān)測(cè)、人群密度監(jiān)測(cè)、口罩率監(jiān)測(cè)、人員定位監(jiān)測(cè)六大功能,對(duì)Python?實(shí)現(xiàn)景區(qū)安防系統(tǒng)感興趣的朋友一起看看吧2022-07-07
anaconda虛擬環(huán)境python?sklearn庫(kù)的安裝過(guò)程
Anaconda是專注于數(shù)據(jù)分析的Python發(fā)行版本,包含了conda、Python等190多個(gè)科學(xué)包及其依賴項(xiàng),這篇文章主要給大家介紹了關(guān)于anaconda虛擬環(huán)境python?sklearn庫(kù)的安裝過(guò)程,需要的朋友可以參考下2023-11-11
Python學(xué)習(xí)筆記之迭代器和生成器用法實(shí)例詳解
這篇文章主要介紹了Python學(xué)習(xí)筆記之迭代器和生成器用法,結(jié)合實(shí)例形式詳細(xì)分析了Python迭代器與生成器的功能、原理、定義及使用方法,需要的朋友可以參考下2019-08-08
淺析python標(biāo)準(zhǔn)庫(kù)中的glob
glob 文件名模式匹配,不用遍歷整個(gè)目錄判斷每個(gè)文件是不是符合。這篇文章主要介紹了python標(biāo)準(zhǔn)庫(kù)中的glob的相關(guān)知識(shí),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2020-03-03
使用Django框架中ORM系統(tǒng)實(shí)現(xiàn)對(duì)數(shù)據(jù)庫(kù)數(shù)據(jù)增刪改查
這篇文章主要介紹了使用Django的ORM實(shí)現(xiàn)對(duì)數(shù)據(jù)庫(kù)數(shù)據(jù)增刪改查方法,文中附含詳細(xì)示例代碼以及過(guò)程詳解,有需要的朋友可以借鑒參考下2021-09-09
詳解python異步編程之a(chǎn)syncio(百萬(wàn)并發(fā))
這篇文章主要介紹了詳解python異步編程之a(chǎn)syncio(百萬(wàn)并發(fā)),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-07-07
利用Python進(jìn)行數(shù)據(jù)清洗的操作指南
數(shù)據(jù)清洗是指發(fā)現(xiàn)并糾正數(shù)據(jù)文件中可識(shí)別的錯(cuò)誤的最后一道程序,包括檢查數(shù)據(jù)一致性,處理無(wú)效值和缺失值等。本文為大家介紹了Python進(jìn)行數(shù)據(jù)清洗的操作詳解,需要的可以參考一下2022-03-03
Python實(shí)現(xiàn)檢測(cè)照片中的人臉數(shù)
這篇文章主要為大家詳細(xì)介紹了如何利用Python語(yǔ)言實(shí)現(xiàn)檢測(cè)照片中共有多少?gòu)埲四?,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2022-08-08

