day12 函数嵌套

一、 args与kwargs

def index(a,b,c):
print(a,b,c) def wrapper(*args,**kwargs): # args=(1,2,3) kwargs={}
index(*args,**kwargs) # index(*(1,2,3) ,**{}) # index(1,2,3) wrapper(b=2,c=3,a=1)

二、函数嵌套

一、函数的嵌套调用:在调用一个函数的过程中,又调用了其他函数
# 函数的嵌套定义: 在函数内又定义了一个函数
# def f1(): # 定义在函数内部的内容有一个效果:函数外无法访问,只有在函数内才可以访问到
from math import pi
def circle(radius,mode=0):
def perimiter(radius):
return 2 * pi * radius def area(radius):
return pi * (radius ** 2) if mode == 0:
return perimiter(radius)
elif mode == 1:
return area(radius)
circle(3,0)

三、函数对象

def foo():  # foo->函数的内存地址
print('from foo') x = 10 # x->10的内存地址 1、可以被赋值
y = x
f = foo
f() 2、可以当做参数传入
def f1(func):
print('====>f1')
func() f1(foo) # f1(函数的内存地址) 3、可以当做返回值
def f1(func):
return func f = f1(foo)
print(f) 4、可以当做容器类型的元素
x = 10
l = [x,foo,foo()]
print(l)
l[1]()

四、名称空间与作用域

名称空间Namespace:存放名字与内存地址绑定关系的地方
# 名称空间分三种:
1、内置名称空间:存放python解释器自带的名字
print(len)
print(input) 2、全局名称空间: 存放的是顶级的名字,如下x、z、f1、xxx都是
x = 100
def f1():
y = 200 if 10 > 3:
z = 300 if True:
xxx = 400 3、局部名称空间:存放的是函数内定义的名字
def f1():
x = 200 f1() # 重要结论1:局部Local-》外层函数Enclosing-》全局Global-》内置Builtin
# L->E->G->B 例1:
def f1():
# len = 200
print(len) len = 100 # 全局顶级代码 f1() print('=====>',len) 例2:LEGB
len = 100
def f1():
# len = 200 def f2():
# len = 300
print(len)
len = 1111111111111111111111111111111111111111111
f2() f1()
# 重要结论2:名称空间的嵌套关系是在函数定义阶段、扫描语法时就确定好的,与调用位置无关 例1:
len = 100
def f1():
# len = 200
def f2():
print(len) return f2 f = f1() # print(f) len = 6666666666666
f() 例2:
len = 100
def f1():
def f2():
print(len)
# len = 200 return f2 f = f1() def foo():
len = 77777
f() foo() 例3
x = 100 def f1():
print(x)
x = 200 f1() # 总结:
全局作用域:全局存活,全局有效
内置名字空间、全局名称空间 局部作用域:临时存活,局部有效
局部名称空间 =============》 global关键字
l = []
x = 100 def foo():
l.append(333) global x
x = 200 foo() print(l)
print(x) =============》 nonlocal关键字

五、闭包函数

闭函数:定义在函数内部的函数
def outter():
def wrapper():
print('====>wrapper') 包函数: 内部函数引用了一个来自于外层函数的变量
def outter():
x = 111
def wrapper():
print('====>wrapper',x)

day12 函数嵌套的更多相关文章

  1. day12函数,三元表达式 ,列表推导式 ,字典推导式,函数对象,名称空间与作用域,函数的嵌套定义

    复习 # 字符串的比较 # -- 按照从左往右比较每一个字符,通过字符对应的ascii进行比较 # 函数的参数 # 1)实参与形参: # -- 形参:在函数定义时()中出现的参数 # -- 实参:在函 ...

  2. day12 函数的嵌套调用 闭包函数,函数对象

    函数嵌套: 函数嵌套: 嵌套指的是,一个物体包含另一个物体,函数嵌套就是一个函数包含另一个函数 按照函数的两个阶段 嵌套调用 指的是在函数的执行过程中调用了另一个函数,其好处可以简化外层大函数的代码, ...

  3. JavaScript ES7 中使用 async/await 解决回调函数嵌套问题

    原文链接:http://aisk.me/using-async-await-to-avoid-callback-hell/ JavaScript 中最蛋疼的事情莫过于回调函数嵌套问题.以往在浏览器中, ...

  4. python之函数嵌套

    python很多特性与JavaScript是相似甚至相同的: 1. 无类型 2. 函数亦对象 .... 自然: python也允许函数嵌套, 这与JavaScript中函数闭包的作用一样....

  5. 不使用回调函数的ajax请求实现(async和await简化回调函数嵌套)

    在常规的服务器端程序设计中, 比如说爬虫程序, 发送http请求的过程会使整个执行过程阻塞,直到http请求响应完成代码才会继续执行, 以php为例子 $url = "http://www. ...

  6. Oracle之分组函数嵌套以及表连接

    --1 数据环境准备 scott 用户下面的emp,dept表 --2 要求 :求平均工资最高的部门编号,部门名称,部门平均工资 select d.deptno,d.dname,e.salfrom(s ...

  7. nodejs批量导入数据eventproxy(回调函数嵌套解决方案)使用实例

    回调函数嵌套解决方案——eventProxy API地址:https://github.com/JacksonTian/eventproxy 1.安装eventproxy 执行npm install ...

  8. python全栈开发-Day9 函数对象、函数嵌套、名称空间与作用域

    一 .函数对象 一 .函数是第一类对象,即函数可以当作数据传递 可以被引用 可以当作参数传递 返回值可以是函数 可以当作容器类型的元素 二. 利用该特性,优雅的取代多分支的if def foo(): ...

  9. python基础—函数嵌套与闭包

    python基础-函数嵌套与闭包 1.名称空间与作用域 1 名称空间分为: 1 内置名称空间   内置在解释器中的名称 2 全局名称空间   顶头写的名称 3 局部名称空间 2 找一个名称的查找顺序: ...

随机推荐

  1. cf 11D A Simple Task(状压DP)

    题意: N个点构成的无向图,M条边描述这个无向图. 问这个无向图中共有多少个环. (1 ≤ n ≤ 19, 0 ≤ m) 思路: 例子: 4 6 1 2 1 3 1 4 2 3 2 4 3 4 答案: ...

  2. spring-cloud-square源码速读(spring-cloud-square-okhttp篇)

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  3. QuantumTunnel:Netty实现

    接上一篇文章内网穿透服务设计挖的坑,本篇来聊一下内网穿透的实现. 为了方便理解,我们先统一定义使用到的名词: UserClient:用户客户端,真实的请求发起方: UserServer:内网穿透-用户 ...

  4. 数组 & 对象 & 函数

    数组 数组也是一个对象,不同的是对象用字符串作为属性名,而数组用数字作为索引,数组的索引从0开始 创建数组: //方式一:构造器,可以在创建数组时指定 Var arr = new Array(1,2, ...

  5. webpack 之js兼容性处理

    webpack 之js兼容性处理 // 用来拼接绝对路径的方法 const {resolve} = require('path') const HtmlWebpackPlugin = require( ...

  6. 【JavaScript实用技巧(二)】Js操作DOM(由问题引发的文章改版,新人大佬都可)

    [JavaScript实用技巧(二)]Js操作DOM(由问题引发的文章改版,新人大佬都可!) 博客说明 文章所涉及的资料来自互联网整理和个人总结,意在于个人学习和经验汇总,如有什么地方侵权,请联系本人 ...

  7. 大一C语言学习笔记(6)---自省篇--流程控制;break,continue,return间的异同;数组应用到循环语句中需要注意的问题;++i 和 i++的异同等。

    下面是傻瓜博主"曾经"犯过的错和一些心得:        ༼ つ ◕_◕ ༽つ 1.要想流程控制学好,一定要学会化繁为简,举栗子: 三目运算符 (略?略:略)---就是一个数字嘛, ...

  8. 100_第一个vue-cli项目

    目录 什么是vue-cli 主要的功能 需要的环境 Node.js : http://nodejs.cn/download/ Git : https://git-scm.com/downloads 安 ...

  9. Maven 依赖调解源码解析(七):总结

    本文是系列文章<Maven 源码解析:依赖调解是如何实现的?>第七篇,也是最后一篇,主要做个总结.请按顺序阅读其他系列文章,系列文章总目录参见:hhttps://www.cnblogs.c ...

  10. 快速从零开始整合SSM,小白包会(1)

    整合SSM,关键就是几个xml的配置. 准备: 1.   Idea(配置好tomcat,可以安装插件freeMybatis,提高效率,安装插件不难,百度经验就有) 2.   下载好数据库MySql,以 ...