日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python装饰器应用论文_python 装饰器应用

發布時間:2025/3/15 python 19 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python装饰器应用论文_python 装饰器应用 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1?注冊回調函數

下面這個示例展示了通過URL的路由來調用相關注冊的函數示例:

class?MyApp():

def?__init__(self):

self.func_map?=?{}

def?register(self,?name):

def?func_wrapper(func):

self.func_map[name]?=?func

return?func

return?func_wrapper

def?call_method(self,?name=None):

func?=?self.func_map.get(name,?None)

if?func?is?None:

raise?Exception("No?function?registered?against?-?"?+?str(name))

return?func()

app?=?MyApp()

@app.register('/')

def?main_page_func():

return?"This?is?the?main?page."

@app.register('/next_page')

def?next_page_func():

return?"This?is?the?next?page."

print?app.call_method('/')

print?app.call_method('/next_page')

注意:

1)上面這個示例中,用類的實例來做decorator。

2)decorator類中沒有__call__(),但是wrapper返回了原函數。所以,原函數沒有發生任何變化。

2 打印日志

from functools import wraps

import inspect

def get_line_number():

return inspect.currentframe().f_back.f_back.f_lineno

def logger(loglevel):

def log_decorator(fn):

@wraps(fn)

def wrapper(*args, **kwargs):

ts = time.time()

result = fn(*args, **kwargs)

te = time.time()

print "function?? = " + fn.__name__,

print "??? arguments = {0} {1}".format(args, kwargs)

#print "??? return??? = {0}".format(result)

print "??? time????? = %.6f sec" % (te-ts)

if (loglevel == 'debug'):

print "??? called_from_line : " + str(get_line_number())

return result

return wrapper

return log_decoratorspam(1,2,3)

3 調用追蹤

import sys,os,linecache

def trace(f):

def globaltrace(frame, why, arg):

if why == "call": return localtrace

return None

def localtrace(frame=1, why=2, arg=4):

if why == "line":

# record the file name and line number of every trace

filename = frame.f_code.co_filename

lineno = frame.f_lineno

bname = os.path.basename(filename)

print "{}({}): {}".format(? bname,

lineno,

linecache.getline(filename, lineno)),

return localtrace

def _f(*args, **kwds):

sys.settrace(globaltrace)

result = f(*args, **kwds)

sys.settrace(None)

return result

return _f

@trace

def xxx():

a=1

print a

xxx() #調用

4 單例模式

#?coding=utf-8

#?測試utf-8編碼

#?單例裝飾器

import?sys

reload(sys)

sys.setdefaultencoding('utf-8')

#?使用裝飾器實現簡單的單例模式

def?singleton(cls):

instances?=?dict()??#?初始為空

def?_singleton(*args,?**kwargs):

if?cls?not?in?instances:??#如果不存在,?則創建并放入字典

instances[cls]?=?cls(*args,?**kwargs)

return?instances[cls]

return?_singleton

@singleton

class?Test(object):

pass

if?__name__?==?'__main__':

t1?=?Test()

t2?=?Test()

#?兩者具有相同的地址

print?t1

print?t2

創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

總結

以上是生活随笔為你收集整理的python装饰器应用论文_python 装饰器应用的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。