中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python裝飾器的定義形式有哪些

發布時間:2022-11-28 09:43:36 來源:億速云 閱讀:133 作者:iii 欄目:開發技術

這篇文章主要講解了“Python裝飾器的定義形式有哪些”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Python裝飾器的定義形式有哪些”吧!

前言

裝飾器(decorator)在Python框架中扮演著重要角色,是Python中實現切面編程(AOP)的重要手段。

aspect-oriented programming (AOP) ,在不改變代碼自身的前提下增加程序功能

不改變代碼自身,但需要在函數和類頭上加一個標注(annotation),這個標注在Python里叫裝飾器,在java里叫注解。
在Python里,一共有四種組合形式。下面一一舉例。

用函數裝飾函數

采用一個函數定義裝飾器:

def decorate(f):
    def wrapper(*args):
        return f(*args)*2
    return wrapper

然后作用在一個函數上:

@decorate
def add(a, b):
	return a + b

測試一下效果:

def test_decorate():
	sum = add(3, 5)
	assert sum == 16

用函數裝飾一個類

這里通過裝飾器實現單例模式:

def singleton(cls):
    instances = {}
    def wrapper(*args, **kwargs):
        if cls not in instances:
          instances[cls] = cls(*args, **kwargs)
        return instances[cls]
    return wrapper

使用該裝飾器:

@singleton
class MyClass:
    def method(self):
        pass

于是,當你定義多個對象時,返回的是同一實例:

obj = MyClass()  # creates a new instance
obj2 = MyClass()  # returns the same instance
obj3 = MyClass()  # returns the same instance
...

用類定義裝飾器,然后裝飾一個函數

先采用類定義一個裝飾器:

class Star:
    def __init__(self, n):
        self.n = n

    def __call__(self, fn):
        @wraps(fn)
        def wrapper(*args, **kwargs):
            result = fn(*args, **kwargs)
            return result
        return wrapper

再作用在一個函數上:

@Star(5)
def add(a, b):
    return a + b

主要是在類中實現__call__方法。上面例子也可以簡化:

class MyDecorator:
    def __init__(self, function):
        self.function = function
     
    def __call__(self, *args, **kwargs):
 
        # We can add some code
        # before function call
 
        self.function(*args, **kwargs)
 
        # We can also add some code
        # after function call.
# adding class decorator to the function
@MyDecorator
def function(name, message ='Hello'):
    print("{}, {}".format(message, name))

用類定義裝飾器,然后裝飾一個類

先定義裝飾器:

class MyClassDecorator(object):
	_instances = dict()

	def __init__(self, name):
		pass

	def __call__(self, cls):
		class WrappedClass(cls):
			def say_hello(self):
				print(f'Hello: {self.username}')
		return WrappedClass

該裝飾器給被裝飾的類上添加了一個方法,名稱為say_hello()。使用如下:

@MyClassDecorator('test')
class MyClass():
	def __init__(self, username):
		self.username = username

然后:

def test_decoratorforclass():
	obj = MyClass('user1')
	obj.say_hello()

打印出: Hello: user1

感謝各位的閱讀,以上就是“Python裝飾器的定義形式有哪些”的內容了,經過本文的學習后,相信大家對Python裝飾器的定義形式有哪些這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

吉木萨尔县| 广河县| 泗阳县| 沧州市| 三穗县| 灌南县| 丹凤县| 潢川县| 论坛| 正定县| 隆子县| 兴宁市| 嘉善县| 贵阳市| 滕州市| 宣汉县| 青河县| 临汾市| 中牟县| 台江县| 扶风县| 体育| 富蕴县| 蓝田县| 中西区| 英吉沙县| 秦皇岛市| 太仆寺旗| 乌兰浩特市| 信宜市| 潍坊市| 民县| 屯留县| 内江市| 新建县| 襄汾县| 温宿县| 湘潭市| 香河县| 登封市| 奎屯市|