class CodeA:
@staticmethod
def foo(self):
print("调用静态方法 foo()")
作为新手而言,看完之后总结之后我只能表示略懂略懂。。。我需要大量修饰符的题目来完善这些认知。。
推荐http://bbs.fishc.org/forum.php?mod=viewthread&tid=95874&highlight=%D7%B0%CA%CE%C6%F7
对装饰器介绍的不错,由浅入深,看后有种豁然开朗的感觉。
小甲鱼,弱弱问一下,,如果被修饰的函数的参数不仅仅是函数的入口地址怎么办,比如这样:
def fun1(fun,y):
print("Begin")
fun(y)
print("End")
@fun1
def fun2(y):
print(y)
.................
................
觉得这里讲得比较简陋,修饰符这个概念是视频教程中没有提出来,而这里也没有给出详细的语法使用方法以及相关注意事项,看得挺蒙蔽的`{:10_266:}
现在是time.perf_counter()函数了 不是time.clock()了
多谢整理和分享{:5_109:}
看到大家都看不懂,我就放心了
改动了之后表达还是有问题啊,比如需要将 func() 重新在 timeslong 中重新写一遍
应该加个"(如:timeslong(func))",真正零基础是看不懂原句的{:10_319:}
了解
这样的:
@timeslong
def f():
...
等价于:
f = tiemslong(f)
对f重新赋值了,所以f() 也就等于tiemslong(f)(),这也是对timeslong函数中加了一个call函数的原因。
感觉有点突兀啊,每太看到关联
类的每个对象是不是都可以使用类方法,和普通方法一样啊,类方法有什么用呢?
感觉看着有点一知半解,以后再回头理解理解
个人觉得这个网址可供理解参考,https://blog.csdn.net/u013471155/article/details/68960244
侵权删
ps:这个网址的部分内容存在错误,但是觉得有助理解
个人理解部分:
原函数的功能不做更改,调用方式不变
增加的功能 = 新建的函数a(新建函数的实参为原函数,返回值也是原函数)
新建函数b包含新建函数a,实参为原函数,返回值为a
b也可以是一个类
@b
加在原函数之前,对原函数进行装饰
Python内置的修饰符:
python中自带的三个b,功能是对实例方法进行类型转变······
对于具体的a、b参数放法,暂时还是没掌握好
我去网上逛了一大圈才弄懂了这个修饰器到底啥意思.....
学到这里就完全蒙了
乱来,你的文章资料不是个人看,而是给很多人学习,这么含糊,在搞什么呢?如果这样不如不发。
本帖最后由 魔法虫虫 于 2018-10-12 17:03 编辑
为什么不能直接用上面的函数直接调用下面的?
直接显示地址是什么鬼?
import time
def timeslong(func):
def call():
start = time.clock()
print("It's time starting!")
func()
print("It's time ending!")
end = time.clock()
return "It's used : %s ."%(end - start)
return call
def f():
y = 0
for i in range(10):
y = y + i +1
print(y)
return y
print(timeslong(f))
运行出来是这个
1
3
6
10
15
21
28
36
45
55
<function timeslong.<locals>.call at 0x000001BDC93C70D0>
看不懂、、、、崩溃