补充:一个星号的  打散和聚合

a, b , *c = [1,2, 1,4]
print( a , b , *c) #1 2 1 4
print(a, b, c) #1 2 [1, 4]
*c , = [1,2,3]
print(*c)

1.函数名的使用

函数名可以当做值赋值给变量
def func():
print(1)
print(func) # 函数的内存地址 a = func
a()
func()# 函数名可以当做值赋值给变量
#函数名可以当做元素放到容器里  
def func2():
print(2) l1 = [func,func2]
print(l1) #函数名可以当做元素放到容器里 l1 = [func(),func2()]#None , None
print(l1)
#发现 函数名先调用 计算  prinT(6+7)=打印 13 不是打印 6+7
                    # 不是从前往后 先计算后面的 后面有值 返回或打印
return aa() # 传的是值
# return aa # 传的是地址
# 楼梯 是 定义  箭头是 调用
def f():
def a():
def b():
def c():
return '传递'
return c()
return b()
return a()
print(f())

2.闭包

#1. 一个嵌套函数
#2.在嵌套函数的内部函数使用外部(非全局的变量)
#满足以上两条
判断 不是 None
def wrapper():
a = 10
def inner():
print(a)
return inner # 返回的地址 第5步
# inner()
print(inner.__closure__)#不是None jius就是闭包
# 普通函数 执行调用完 了就销毁了
#python中 闭包 会进行内存驻留
# money = 10 # 以后不要这么干
#全局里存放 会有污染和不安全的现象
# 面试必问 , 装饰器 ---装饰器的本质就是闭包
# 闭包有个弊端: 会出现内存泄露
money = 10
def wrapper():
money = 10
def inner(num):
nonlocal money
money += num
print(money)
return inner
wrapper()(100)
 关于内存地址(列表和字典哪个寻值快?)

列表   (有序空间)每一个值对应一个 内存地址,但是由于找到了第一个值,然后依次取下面的数时,遍历而省去了查找,所以相对省时间。--》链表

字典   每一个键   对应一个哈希表   然后对着  哈希表去寻找值, 所以每一个都须寻找内存地址 ,所以相对列表链式浪费些时间
1.3 迭代器
'''
可迭代对象 可被for 循环的就是可迭代对象
python 协议: 具有.__init__方法的就是可迭代对象
a = 对象.__iter__#创建一个迭代器
具有a.__iter__a.__next__的就是迭代器
'''
l1 = [1,2,3]
print(l1.__iter__) #地址
a = l1.__iter__() #赋值
print(a.__next__()) #打印第一个
print(a.__next__())
print(a.__next__()) #若再打印则报错StopIteration
# print(a.__next__())#StopIteration 没了取不到

for 循环

对可迭代的内容  进行一个个遍历 从前到后   就是构成一个标准迭代器

for i in [1,2,3]:
print(i)

for 循环的迭代器原理

#  做出 for 的机制
li = [1,2,3]
em = li.__iter__()
while 1:
try: #尝试
print(em.__next__())
except StopIteration: #错误类型
# print('你不能这么干')
break
#int str list 工厂模式  把零件往里面一扔 车出来了
# 迭代器特性:
# 惰性机制 : 点一个用一个
# 不能从下向上走
# 一次性的,用完就没了
# 省内存
1.4 递归
递归的最大深度 官方1000 实际993    
递归的效率比较低,尾递归的用时 和 for的用时 是一样的,比for慢
递归的应用场景:
在不明确要循环的次数时候,可以用递归
递归操作文件目录
  def func(n):
n+=1
print(n)
if n == 5:
return
func(n)
func(2)
												

day10作业—(闭包迭代器递归)的更多相关文章

  1. day11 第一类对象 闭包 迭代器

    今日主要内容: 1 . 第一类对象 -->函数名--> 变量名 2. 闭包 -->函数的嵌套 3. 迭代器 --> 固定的思想 for 循环 第一类对象  : 函数对象介意向变 ...

  2. 孤荷凌寒自学python第十九天python函数嵌套与将函数作为返回对象及闭包与递归

    孤荷凌寒自学python第十九天python函数嵌套与将函数作为返回对象及闭包与递归 (完整学习过程屏幕记录视频地址在文末,手写笔记在文末) Python函数非常的灵活,今天学习了python函数的以 ...

  3. 042-PHP使用闭包函数递归无限级分类

    <?php //使用闭包函数递归无限级分类 function demo($array){ # 用于存储递归后的队列 $data = []; # 递归函数 $func = function (&a ...

  4. Python函数03/函数名的第一类对象及使用/f 格式化/迭代器/递归

    Python函数03/函数名的第一类对象及使用/f 格式化/迭代器/递归 目录 Python函数03/函数名的第一类对象及使用/f 格式化/迭代器/递归 内容纲要 1.函数名的第一类对象及使用 2.f ...

  5. python 第一类对象 闭包 迭代器

    ########################总结########################### 1. 函数名 -> 第一类对象 函数名就是变量名. 函数可以赋值 函数可以作为集合类的 ...

  6. Python 内置函数、作用域、闭包、递归

    一.内置函数如何使用 help()一下: 如想看min()咋用?在shell中:help(min) 二.部分内置函数 (一).排序:sorted() li = [(1, 2, 3, 4), (7, 8 ...

  7. Python_Mix*函数名的使用以及第一类对象,闭包,迭代器,for循环的内部机制

    一:函数名的应用(第一类对象) 函数名的命名规范和变量是一样的,函数名其实就是变量名, 0)函数名可以赋值给其他变量 def func(): #定义一个名为func的函数 print('my ange ...

  8. Day11--Python--函数名,闭包,迭代器

    通过 lst.__iter__()拿到lst.的迭代器 1.函数名第一类对象 函数名就是变量名 1.函数名可以像变量一样互相赋值. 2.可以作为函数的参数,进行传递 3.可以作为返回值返回 4.可以作 ...

  9. python摸爬滚打之day11----函数闭包,迭代器

    1.函数名 函数名就是一个变量名, 函数名存储的是该函数的内存地址.    函数名都可以进行哪些应用? 函数名可以赋值给其他的变量; 函数名可以作容器里的元素使用; 函数名可以当做形参传进另一函数; ...

随机推荐

  1. centos 7 redis-4.0.11 哨兵

    redis-master:192.168.199.223 redis-slave_1: 192.168.199.224 redis-slave_2: 192.168.199.252 redis-mas ...

  2. awk技巧 nginx access.log

    1.1 介绍 awk其名称得自于它的创始人 Alfred Aho .Peter Weinberger 和 Brian Kernighan 姓氏的首个字母.实际上 AWK 的确拥有自己的语言: AWK ...

  3. 二叉树中和为某一值的路径(python)

    题目描述 输入一颗二叉树的跟节点和一个整数,打印出二叉树中结点值的和为输入整数的所有路径.路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径.(注意: 在返回值的list中,数组长度大 ...

  4. 旋转数组的最小数字(python)

    题目描述 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转. 输入一个非减排序的数组的一个旋转,输出旋转数组的最小元素. 例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋 ...

  5. TOJ 3589 likaer的最长点距

    传送门:http://acm.tzc.edu.cn/acmhome/problemdetail.do?&method=showdetail&id=3589 时间限制(普通/Jav a) ...

  6. 160. Intersection of Two Linked Lists (List;Two-Pointers)

    Write a program to find the node at which the intersection of two singly linked lists begins. For ex ...

  7. f5创建VS

    1.1) 2) 3) 4) 5) 2.Availability 1)Pool 中的monitor保障服务高可用 2)Pool 失败机制一 Fallback Host 最后的host( 使用于HTTP ...

  8. 【校招面试 之 C/C++】第32题 C++ 11新特性(三)之for关键字

    1.for循环的一般写法: int arr[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 }; for (int i = 0; i < 10; i++) cout ...

  9. jsp选项过长自动换行

    自动换行前是这样的 从源码发现“打发的所发生的7”所在span跨行了,宽度为整行的宽度,不再是自身的实际宽度(一列时所占的宽度) 我的思路是要把这个换行元素前加上<br/>,使得该元素换行 ...

  10. easyui的dialog

    代码: <div id="titledialos" class="easyui-dialog" title="×××" data-op ...