您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

深入浅出分析Python装饰器用法

5b51 2022/1/14 8:16:44 python 字数 5233 阅读 331 来源 www.jb51.cc/python

本文实例讲述了Python装饰器用法。分享给大家供大家参考,具体如下: 用类作为装饰器

概述

本文实例讲述了Python装饰器用法分享给大家供大家参考,具体如下:

用类作为装饰器

示例一

最初代码

class bol(object):
 def __init__(self,func):
  self.func = func
 def __call__(self):
  return "<b>{}</b>".format(self.func())
class ita(object):
 def __init__(self,func):
  self.func = func
 def __call__(self):
  return "<i>{}</i>".format(self.func())
@bol
@ita
def sayhi():
 return 'hi'

改进一:

class sty(object):
 def __init__(self,tag):
  self.tag = tag
 def __call__(self,f):
  def wraper():
   return "<{tag}>{res}</{tag}>".format(res=f(),tag=self.tag)
  return wraper
@sty('b')
@sty('i')
def sayhi():
 return 'hi'

改进二:

class sty(object):
 def __init__(self,*tags):
  self.tags = tags
 def __call__(self,f):
  def wraper():
   n = len(self.tags)
   return "{0}{1}{2}".format(('<{}>'*n).format(*self.tags),f(),('</{}>'*n).format(*reversed(self.tags)))
  return wraper
@sty('b','i')
def sayhi():
 return 'hi'
print(sayhi())

改进三:

class sty(object):
 def __init__(self,f):
  def wraper(*args,**kwargs):
   n = len(self.tags)
   return "{0}{1}{2}".format(('<{}>'*n).format(*self.tags),f(*args,**kwargs),'i')
def say(word='Hi'):
 return word
print(say())
print(say('Hello'))

示例二

最初代码

import threading
import time
class DecoratorClass(object):
  def __init__(self):
    self.thread = None
  def __call__(self,func,*args,**kwargs):
    def wrapped_func(*args,**kwargs):
      curr_thread = threading.currentThread().getName()
      self.thread = curr_thread
      print('\nthread name before running func:',self.thread)
      ret_val = func()
      print('\nthread name after running func:',self.thread)
      return ret_val
    return wrapped_func
@DecoratorClass()
def decorated_with_class():
  print('running decorated w class')
  time.sleep(1)
  return
threads = []
for i in range(5):
  t = threading.Thread(target=decorated_with_class)
  threads.append(t)
  t.setDaemon(True)  # 守护
  t.start()

改进:进程锁

import threading
import time
class DecoratorClass(object):
  def __init__(self):
    self.thread = None
    self.lock = threading.Lock()
  def __call__(self,**kwargs):
      self.lock.acquire()
      curr_thread = threading.currentThread().getName()
      self.thread = curr_thread
      print('thread name before running func:',self.thread)
      self.lock.release()
      return ret_val
    return wrapped_func
@DecoratorClass()
def decorated_with_class():
  print('Let me sleep 1 second...')
  time.sleep(1)
  return
threads = []
for i in range(5):
  t = threading.Thread(target=decorated_with_class)
  threads.append(t)
  t.start()

更多关于Python相关内容可查看本站专题:《Python数据结构与算法教程》、《Python Socket编程技巧总结》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》及《Python入门与进阶经典教程

希望本文所述对大家Python程序设计有所帮助。

总结

以上是编程之家为你收集整理的深入浅出分析Python装饰器用法全部内容,希望文章能够帮你解决深入浅出分析Python装饰器用法所遇到的程序开发问题。


如果您也喜欢它,动动您的小指点个赞吧

除非注明,文章均由 laddyq.com 整理发布,欢迎转载。

转载请注明:
链接:http://laddyq.com
来源:laddyq.com
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


联系我
置顶