day11迭代器 and 闭包
- 函数名的使⽤以及第一类对象
函数名是一个变量, 但它是一个特殊的变量, 与括号配合可以执行函数的变量.
函数名就是变量名, 函数名存储的是函数的内存地址
函数名可以赋值给其他变量
函数名可以当做容器类的元素
函数名可以当做函数的参数
函数名可以作为函数的返回值
- 闭包
闭包就是内层函数, 对外层函数(非全局)的变量的引⽤. 叫闭包
可以使用__closure__来检测函数是否是闭包. 使⽤函数名.__closure__返回cell就是
闭包. 返回None就不是闭包
作用:
1. 保护变量不受侵害(javascript)
2. 让一个变量常驻内存迭代器
- 迭代器
s = "我的哈哈哈"
print(dir(s)) # 可以打印对象中的方法和函数
print(dir(str)) # 查看str能够执行的操作. 内部的方法
print(dir(tuple)) …
print(dir(list))
print(dir(set))
print(dir(dict))
寻找__iter__ 如果能找到. 那么这个类的对象就是⼀个可迭代对象.
dir() 查看变量能够执行的方法(函数)
Iterator: 迭代器, __iter__(), __next__()
Iterable: 可迭代的, __iter__()
迭代器本身是可迭代的
for循环的流程:
it = lst.__iter__()# 获取新的迭代器
while 1:
try:
el = it.__next__()
for循环的循环体
except StopIteration:
break
从迭代器中获取数据的唯一方法: __next__()
# 三个特点:
# 1. 节省内存 (生成器)
# 2. 惰性机制, 必须用__next__()来获取数据
# 3. 只能往前. 不能后退
# 如何判断一个数据是否是可迭代对象
# 1. dir() -> __iter__ 可迭代的
# dir() -> __next__ 迭代器
# lst = ["秦始皇", "汉武帝", "孝文帝", "隋炀帝", "李世民"]
# print("__iter__" in dir(lst)) # True 可迭代的
# print("__next__" in dir(lst)) # False 不是迭代器
# it = lst.__iter__() # 迭代器
# print("__iter__" in dir(it)) # True 迭代器本身就是可迭代的
# print("__next__" in dir(it)) # True
2.
# collections 关于集合类的相关操作
# Iterable : 可迭代的
# Iterator : 迭代器
from collections import Iterable, Iterator
print(isinstance(lst, Iterable)) # True
print(isinstance(lst, Iterator)) # False
print(isinstance({1,2,3}, Iterable)) # True, 可以使用for循环