5402285zz 发表于 2021-7-13 19:16:52

装饰器的问题

def display_time(func):
        def warpper():
                t1 = time.time()
                func()
                t2 = time.time()
                print(t2-t1)
        return wrapper

@display_time
def count_prime_nums():
        count = 0
        for i in range(2,10000):
                if is_prime(i):
                        count = count +1
        return count

如果运行count_prime_nums(),运行后没有给出count的值
我的理解是:
count 只是返回给count_prime_nums(),而最后运行的相当于wrapper,而count没有返还给wrapper,所以没有打印出count的值:
我分析的对不对,请大佬指点!

深谙流年 发表于 2021-7-13 19:48:35

不是没有返还,是count_prime_nums()运行后就返回了count,然后需要打印出来,而wrapper函数中没有对返回count的操作,所以啥都没有{:10_256:}

5402285zz 发表于 2021-7-14 18:57:45

深谙流年 发表于 2021-7-13 19:48
不是没有返还,是count_prime_nums()运行后就返回了count,然后需要打印出来,而wrapper函数中没有对返回 ...

如果不加装饰器,调用函数count_prime_nums()不是不用打印就会出count

深谙流年 发表于 2021-7-14 19:22:21

5402285zz 发表于 2021-7-14 18:57
如果不加装饰器,调用函数count_prime_nums()不是不用打印就会出count

函数返回后是一个值,是需要打印才能显示出来的,除非你把return换成print,这样可以调用函数就可以直接打印处理,

5402285zz 发表于 2021-7-14 19:28:58

深谙流年 发表于 2021-7-14 19:22
函数返回后是一个值,是需要打印才能显示出来的,除非你把return换成print,这样可以调用函数就可以直接 ...

不对吧,如果return可以不用print,就可以直接打印

深谙流年 发表于 2021-7-14 19:34:23

本帖最后由 深谙流年 于 2021-7-14 19:36 编辑

5402285zz 发表于 2021-7-14 19:28
不对吧,如果return可以不用print,就可以直接打印

不行

深谙流年 发表于 2021-7-14 19:36:54

深谙流年 发表于 2021-7-14 19:34
不行

我刚试过,直接调用的话啥都没有,必须打印
页: [1]
查看完整版本: 装饰器的问题