两个装饰器为什么也只打印了一次test,按说不应该是两次吗

两个装饰器为什么也只打印了一次test,按说不应该是两次吗

两个装饰器为什么也只打印了一次test,按说不应该是两次吗

正在回答

登陆购买课程后可参与讨论,去登陆

2回答

同学你好:

http://img1.sycdn.imooc.com//climg/5df762050949937d03470632.jpg

装饰器的顺序是:

log_in()

log()

执行的顺序·:

log->log_in

那么执行的时候先执行log装饰器的内容,执行后程序还没有结束要继续执行log_in装饰器。

所以当执行log_in函数时,这时要装饰的内容变为:

start

ok

end

所以最终执行的效果为:

http://img1.sycdn.imooc.com//climg/5df762230980abe101470104.jpg

如果我解决了同学的问题,请采纳!学习愉快^_^。


  • 游云浮世绘 提问者 #1
    结合专栏里的文章,我猜这特么是 log_in(log), log函数被作为参数传给log_in了是不是,然后test函数是作为参数传给log的,这特么的就是log_in(log(test)),是也不是?嗯,本大爷真是天才。
    2019-12-16 19:12:16
好帮手乔木 2019-12-16 18:40:09

同学你好:

两层装饰器调用了该函数一次。

如果我解决了同学的问题,请采纳!学习愉快^_^。

  • 提问者 游云浮世绘 #1
    这两个装饰器内的代码到底按什么顺序执行的?都有该函数的调用啊,按说不应该是两次么?
    2019-12-16 18:48:50
问题已解决,确定采纳
还有疑问,暂不采纳

恭喜解决一个难题,获得1积分~

来为老师/同学的回答评分吧

0 星
1.Python零基础入门
  • 参与学习           人
  • 提交作业       2727    份
  • 解答问题       8160    个

想要进入Python Web、爬虫、人工智能等高薪领域,你需要掌握本阶段的Python基础知识,课程安排带你高效学习轻松入门,学完你也能听得懂Python工程师的行业梗。

了解课程
请稍等 ...
意见反馈 帮助中心 APP下载
官方微信

在线咨询

领取优惠

免费试听

领取大纲

扫描二维码,添加
你的专属老师