函数名的应用(第一对象) 闭包 装饰器

02,函数名的应用(第一对象)。
# 1,直接打印函数名得到的是函数的内存地址 <function func1 at 0x0000000002876B70>
# print(func1)
#2,函数名可以赋值运算。
# def func1():
#     print(666)
# f1 = func1
# f1()

# 3, 函数名可以作为函数的参数。
# def func1():
#     print(666)
#
# def func2(x):
#     x()
#     print(555)
# func2(func1)

 

 
# 4,函数名可以作为容器类数据类型的元素。
# def func1():
#     print(666)
#
# def func2():
#     print(222)
#
# def func3():
#     print(111)
#
# def func4():
#     print(777)
# l1 = [func1, func2, func3, func4]
# for i in l1:
#     i()
# dic1 = {
#     1:func1,
#     2:func2,
#     3:func3,
#     4:func4,
# }
# dic1[1]()

 

 
# 5,函数名可以当做函数的返回值
def func1():
    print(666)


def func2(x):  # x = func1
    print(222)
    return x
ret = func2(func1)
ret()

 



03,闭包。
# 内层函数对外层函数非全局变量的引用就叫闭包
#判断是不是闭包 函数名.__closure__
# 返回的None则不是闭包,返回的是cell.... 则是闭包
# 闭包有什么用?
#当执行一个函数时,如果解释器判断此函数内部闭包存在,这样
#Python就一个机制,闭包的所在的临时名称空间不会随着函数的执行完毕而消失。
# def func1():
#     name = '老男孩'
#
#     def inner():
#         print(name)
#     inner()
#     print(inner.__closure__)  # <cell at 0x000000000282A768: str object at 0x0000000002856E10>
#
# func1()
# def func1():
#     global name
#     name = '老男孩'
#     def inner():
#         print(name)
#     inner()
#     print(inner.__closure__)  # None
# func1()
# def func1(x):   # x = '老男孩'
#     def inner():
#         print(x)
#     inner()
#     print(inner.__closure__)   #(<cell at 0x00000208229EEE88: str object at 0x0000020822D436F0>,)
# name = '老男孩'
# func1(name)

 

def func():
    def func1():
        name ="老男孩"
    def func2():
        nonlocal name
        name = "alex"
    def func3():
        global name
        name = "太白"
    name = "日天"
    func1()
    print(name)  # 1 日天
    func2()
    print(name)  # 2,alex
    func3()
    print(name)  # 3,alex
func()
print(name)  # 4,太白
# from urllib.request import urlopen
#
# def index():
#     url = "http://www.xiaohua100.cn/index.html"
#     def get():
#         return urlopen(url).read()
#     return get
#
# xiaohua = index()
# content = xiaohua()
#
# print(content)

 


04,装饰器。

#装饰器功能:在不改变原函数的基础上,为原函数增加一些额外的功能,log,登录注册,等等.


测试程序的效率
import time
'''第一版本,测试函数low'''
# def login():
#     time.sleep(0.3)
#     print('洗洗更健康...')
#
# def timmer():
#     start_time = time.time()
#     login()
#     end_time = time.time()
#     print('此函数的执行时间%s' % (end_time - start_time))
# timmer()

 

# 改变了我原来执行函数的执行方式,不好
# def login():
#     time.sleep(0.3)
#     print('洗洗更健康...')
# # login()
#
# def register():
#     time.sleep(0.4)
#     print('洗洗更健康22222...')
# # register()
# def timmer(f):
#     start_time = time.time()
#     f()
#     end_time = time.time()
#     print('此函数的执行时间%s' % (end_time - start_time))
#
# timmer(login)
# timmer(register)

 

# 虽然执行函数的方式已经无限接近于原方式,但是更麻烦了,增加了两步代码。改
# def login():
#     time.sleep(0.3)
#     print('洗洗更健康...')
# # login()
#
# def timmer(f):
#     start_time = time.time()
#     f()
#     end_time = time.time()
#     print('此函数的执行时间%s' % (end_time - start_time))
#
# f1 = login  # 将login函数名给了f1
# login = timmer  # 将timmer函数名给了login
# login(f1)  # timmer(login)

 

# 初级装饰器
# def login():
#     time.sleep(0.3)
#     print('洗洗更健康...')
# # login()
#
# def timmer(f):  # f = login函数名
#
#     def inner():
#         start_time = time.time()
#         f()  # login()
#         end_time = time.time()
#         print('此函数的执行时间%s' % (end_time - start_time))
#     return inner
#
# login = timmer(login)  # inner 此login是新变量
# login()  # inner()

# name = 'alex'
# name = '老男孩'

 

# 简单版装饰器  语法糖
# def timmer(f):  # f = login函数名
#     def inner():
#         start_time = time.time()
#         f()  # login()
#         end_time = time.time()
#         print('此函数的执行时间%s' % (end_time - start_time))
#     return inner
#
# @timmer  # login = timmer(login)  # inner 此login是新变量
# def login():
#     time.sleep(0.3)
#     print('洗洗更健康...')
# login()

# @timmer  # register = timmer(register)
# def register():
#     time.sleep(0.2)
#     print('洗洗更健康22...')



posted @ 2018-05-11 20:57  HoneyCY  阅读(164)  评论(0编辑  收藏  举报