装饰器 decorator或者称为包装器,是对函数的一种包装。
它能使函数的功能得到扩充,而同时不用修改函数本身的代码。
它能够增加函数执行前、执行后的行为,而不需对调用函数的代码做任何改变。
import time
class timeslong:
def __init__(self,func):
self.f = func
def __call__(self):
start = time.clock()
print("It's time starting ! ")
self.f()
print("It's time ending ! ")
end = time.clock()
return "It's used : %s ." % (end - start)
@timeslong
def f():
y = 0
for i in range(10):
y = y + i + 1
print(y)
return y
print(f())
g=timeslong(f)
g()
#这个程序在运行g()的时候,会把it’s time starting和 it’s time ending这句话打两遍,不知道为什么?
第二大段程序勘误:
1.没有引进 import time
2.声明类的首字母要大写
3.缩进问题
早起的达仙僧 发表于 2017-3-19 10:51
一开始的例子可以写成这样啊,没看懂为什么要用装饰器
我也是这么觉得,感觉修饰符有点脱裤子放屁,多此一举!
完全看不懂,为什么不专门讲一节课
看了大家的回复,没有搞懂的人占多数,那么长时间都没有细致地讲一下,看来小甲鱼对装饰器这个东西也是含含糊糊,没办法讲清楚吧
def call()
return call()
这个嵌套有点多余啊,请问有什么作用吗?不写也不影响。
内置修饰符讲得很泛,不好理解啊。
代码其实可以更加简洁点,而且代码的缩进有问题。 另外def print_hello(cls): 里面的(cls)怎么理解,现在还有点晕晕的。
class Hello:
@classmethod
def print_hello(cls):
print('Hello')
Hello.print_hello()
看懂了@classmethod,本来类的方法,必须在类实例化对象之后才能调用,现在可以直接通过类来调用,不需要实例化具体的对象,应该是这样的吧{:10_279:}
本贴可能有错误,@classmethod语句之前应加一个缩进符
不太懂
自从学了编程,感觉智商越来越不够用了
没看懂,需要把逻辑解释清楚
是我智商不够还是没解释清楚,
前面课程都秒懂的,怎么到这就一点也看不懂啊,小甲鱼,快出来解释清楚点T_T
还可以!!!支持小甲鱼!!!
读了好几遍才看懂。
结合其他的解说
#修饰符的例子,这个比较容易懂
def fun1(f):
print("fun1的传入参数:", f)
def fun2(f):
print("fun2的传入参数:", f)
return 2
def fun3(f):#第一步执行fun3时,传入的参数是fun5的函数体
print("fun3的传入参数:", f)
return 3
@fun1 #第三步 执行fun1, 把返回值付给fun5这个字符串(如果有返回值,没有为None)
@fun2 #第二步 执行fun2,并将其返回值作为参数传入fun1
@fun3 #第一步 把fun5函数体作为参数传入fun3,运行fun3并将其返回值作为参数 传入fun2
def fun5():
pass
print(fun5) #这里不能像这样fun5()调用了,fun5=fun1(fun2(fun3)), fun5相当于fun1的返回值了,是一个字符串
#楼主内置的修饰符那里缩进不对,所以类方法的例子无法运行,下面改了以下,可以运行了
class Hello(object):
def __init__(self):
pass
@classmethod
def print_hello(cls):
print("Hello")
Hello.print_hello()
看不太懂