找回密码
 立即注册
首页 业界区 业界 python中可变参数与装饰器的例子

python中可变参数与装饰器的例子

恙髡 2025-6-13 09:44:00
python的可变参数

方法定义
  1. #*args是可以传list类型的可变参数,**kwargs是可以传dict的可变参数
  2. def wrapper(*args, **kwargs):
复制代码
使用示例
  1. def foo(*args, **kwargs):
  2.     print 'args = ', args
  3.     print 'kwargs = ', kwargs
  4.     print '---------------------------------------'
  5. if __name__ == '__main__':
  6.     foo(1,2,3,4)
  7.     foo(a=1,b=2,c=3)
  8.     foo(1,2,3,4, a=1,b=2,c=3)
  9.     foo('a', 1, None, a=1, b='2', c=3)
复制代码
输出结果:
  1. 输出结果如下:
  2. args =  (1, 2, 3, 4)
  3. kwargs =  {}
  4. ---------------------------------------
  5. args =  ()
  6. kwargs =  {'a': 1, 'c': 3, 'b': 2}
  7. ---------------------------------------
  8. args =  (1, 2, 3, 4)
  9. kwargs =  {'a': 1, 'c': 3, 'b': 2}
  10. ---------------------------------------
  11. args =  ('a', 1, None)
  12. kwargs =  {'a': 1, 'c': 3, 'b': '2'}
复制代码
例子来源《Python tips: 什么是*args和**kwargs? - MK2 - 博客园 (cnblogs.com)》

装饰器例子

搭配装饰器使用,用来判断是否为空
  1. #定义一个函数,并进行wrapper一层,用来当作装饰器
  2. def leftTopUICheck(func):
  3.         def wrapper(*args, **kwargs):
  4.                 if hasattr(xxglobal.rds, 'MainPartLeftTopUI'):
  5.                         return func(*args, **kwargs)
  6.                 else:
  7.                         return
  8.         return wrapper
  9. @leftTopUICheck
  10. def setLeftTopPictureFrameRes(filename):
  11.         xxglobal.rds.MainPartLeftTopUI.setPictureFrameRes(filename)
复制代码
定义

@符号是一个语法糖,当执行函数时,会把当前函数传入到@指向的函数中执行。

装饰器用途

结合项目代码来看,目前我们大多是用在前置检查,且会把装饰器函数定义在sys.path内的文件中,避免每次使用都要import。如果装饰器的函数实现在同一个文件中则不需要import。

装饰器的优缺点

装饰器是 Python 中的一种强大工具,它们有许多优点,但也有一些潜在的缺点。
优点:

  • 代码重用:装饰器允许你在多个函数或方法中重用代码。你可以创建一个装饰器来执行一些通用的任务,然后将它应用到任何需要这些任务的函数上。
  • 代码组织:装饰器可以帮助你更好地组织你的代码。你可以将相关的代码放在同一个装饰器中,这样可以使你的代码更易于理解和维护。
  • 扩展性:装饰器允许你在不修改原始函数代码的情况下添加新的功能。这使得装饰器成为一种强大的工具,用于扩展和修改现有的代码。
缺点:

  • 复杂性:装饰器可能会增加代码的复杂性,特别是对于不熟悉装饰器的开发者来说。装饰器的行为可能会让人困惑,特别是当装饰器链或嵌套装饰器被使用时。
  • 调试难度:由于装饰器修改了函数的行为,所以它可能会使得调试变得更加困难。错误可能会隐藏在装饰器中,而不是在你的函数中。
  • 性能开销:装饰器可能会引入额外的性能开销,因为它们在函数调用之前和之后添加了额外的操作。
总的来说,装饰器是一种非常有用的工具,但是需要谨慎使用。在使用装饰器时,你应该确保你完全理解了它们的行为,并且考虑到了它们可能带来的潜在问题。

装饰器导入就会执行
  1. def my_decorator(func):
  2.     print("Decorator is being executed!")
  3.     def wrapper():
  4.         print("Function is being executed!")
  5.         func()
  6.     return wrapper
  7. @my_decorator
  8. def my_function():
  9.     print("Hello, world!")
  10. # 当import这个module时就会执行输出:
  11. # Decorator is being executed!
复制代码
装饰器与C#

在C#中有Attribute,写法上和装饰器一样都是在方法名的上行加上,它也可以达到装饰器的一些功能。
  1. //MenuItem 定义:
  2. public MenuItem(string itemName, bool isValidateFunction)
  3.    
  4. //用法
  5. [MenuItem("Assets/开启XXX", false)]
  6. public static void openXXFunc()
  7. {
  8. }
复制代码
但是如果要实现装饰器完整的前置检查,在C#中我一般是传入一个(Action callback)来处理。
  1. void Check(Action callback){
  2.     if (not 前置检查) return;
  3.     callback.Invoke();
  4. }
复制代码
来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
您需要登录后才可以回帖 登录 | 立即注册