zoukankan      html  css  js  c++  java
  • day16_函数嵌套及对象


    闭包概念:在一个内部函数中,对外部作用域的变量进行引用,(并且一般外部函数的返回值为内部函数),那么内部函数就被认为是闭包
    闭包的作用;保存函数的状态信息

    def
    login(): print('登录功能') def transfer(): print('转账功能') def check_banlance(): print('查询余额') def withdraw(): print('提现') def register(): print('注册') func_dic = { '0': ['退出', None], '1': ['登录', login], '2': ['转账', transfer], '3': ['查询余额', check_banlance], '4': ['提现', withdraw], '5': ['注册', register] } # func_dic['1']() while True: for k in func_dic: print(k, func_dic[k][0]) choice = input('请输入命令编号:').strip() if not choice.isdigit(): print('必须输入编号,傻叉') continue if choice == '0': break # choice='1' if choice in func_dic: func_dic[choice][1]() else: print('输入的指令不存在')

    函数的嵌套

    # 2、函数的嵌套定义:在函数内定义其他函数
    # def f1():
    #     def f2():
    #         pass
    
    
    # 圆形
    # 求圆形的求周长:2*pi*radius
    def circle(radius,action=0):
        from math import pi
    
        def perimiter(radius):
            return 2*pi*radius
    
        # 求圆形的求面积:pi*(radius**2)
        def area(radius):
            return pi*(radius**2)
    
        if action == 0:
            return 2*pi*radius
    
        elif action == 1:
            return area(radius)
    
    circle(33,action=0)

    闭包函数

    # 一:大前提:
    # 闭包函数=名称空间与作用域+函数嵌套+函数对象
    #        核心点:名字的查找关系是以函数定义阶段为准
    
    # 二:什么是闭包函数
    # "闭"函数指的该函数是内嵌函数

    # "包"函数指的该函数包含对 外层函数作用域名字的引用 (不是对全局作用域) # 闭包函数:名称空间与作用域的应用+函数嵌套
    # def f1(): # x = 33333333333333333333 # def f2(): # print(x) # f2() # # # x=11111 # def bar(): # x=444444 # f1() # # def foo(): # x=2222 # bar() # # foo() # 闭包函数:函数对象 # def f1(): # x = 33333333333333333333 # def f2(): # print('函数f2:',x) # return f2 # # f=f1() # # print(f) # # # x=4444 # # f() # def foo(): # x=5555 # f() # # foo() # 三:为何要有闭包函数=》闭包函数的应用 # 两种为函数体传参的方式 # 方式一:直接把函数体需要的参数定义成形参 # def f2(x): # print(x) # # f2(1) # f2(2) # f2(3) # 方式二: # def f1(x): # x=3 # x=3 # def f2(): # print(x) # return f2 # # x=f1(3) # print(x) # # x() import requests # 传参的方案一: # def get(url): # response=requests.get(url) # print(len(response.text)) # # get('https://www.baidu.com') # get('https://www.cnblogs.com/linhaifeng') # get('https://zhuanlan.zhihu.com/p/109056932') # 传参的方案二: def outter(url): # url='https://www.baidu.com' def get(): response=requests.get(url) print(len(response.text)) return get baidu=outter('https://www.baidu.com') baidu() cnblogs=outter('https://www.cnblogs.com/linhaifeng') cnblogs() zhihu=outter('https://zhuanlan.zhihu.com/p/109056932')
  • 相关阅读:
    MySql索引
    HashMap 底层解析
    https超文本安全传输协议
    多线程
    过滤器和拦截器
    计算机操作系统
    计算机网络
    java线程内存模型JMM
    jvm
    数据库
  • 原文地址:https://www.cnblogs.com/pythonwork/p/15589325.html
Copyright © 2011-2022 走看看