一、协程
其原理是当一个 greenlet 遇到 IO(指的是 input output 输入输出,比如网络、文件操作等)操作时,比如访问网络,就自动切换到其他的 greenlet,等到 IO 操作完成,再在适当的时候切换回来继续执行。
由于 IO 操作非常耗时,经常使程序处于等待状态,有了 gevent 为我们自动切换协程,就保证总有 greenlet 在运行,而不是等待 IO。
1、迭代器(Iterator)
(1)、判断能否迭代
(2)、想要迭代必须有__iter__方法
(3)、__iter__中的return返回的是一个迭代器(iter__和__next)
(4)、可以使用 isinstance() 判断一个对象是否是 可迭代的(Iterable) 对象
1-1、判断是不是可以迭代,用Iterable
from collections import Iterable
isinstance({}, Iterable) --> True
isinstance((), Iterable) --> True
isinstance(100, Iterable) --> False
1-2、判断是不是迭代器,用Iterator
from collections import Iterator
isinstance({}, Iterator) --> False
isinstance((), Iterator) --> False
isinstance( (x for x in range(10)), Iterator) --> True
1-3、凡是可以for循环的,都是Iterable
凡是可以next()的,都是Iterator
集合数据类型如list,truple,dict,str,都是Itrable而不是Iterator,但可以通过iter()函数获得一个Iterator对象。
Python中的for循环就是通过next实现的
2、生成器(generator)
(1)、是特殊的迭代器
(2)、如果一个函数中有yield语句,那么你的这个就不是函数了,而是一个生成器的模板。------>yield 后面的变量把返回值返回给创建生成器的对象--------->yield a ------->obj = create_num(10)
3、迭代器与生成器的特点及区别
生成器:可以没有iter和next方法,只需要有yield的就可以了,是特殊的迭代器。
迭代器: 可以迭代就是可以使用for,必须有iter方法和next方法,iter的return返回值是一个迭代器。
迭代器的特点:保存生成的方法,而不是生成的结果,可以用很少的空间完成.
生成器的特点yield:可以让函数先暂停执行,可以恢复上一次的值,继续执行.
4、greenlet
(1)、sudo pip3 install greenlet
(2)、通过 对象.switch()来实现切换
5、gevent
(1)、sudo pip3 install gevent
(2)、gevent.joinall([
gevent.spawn(指向的变量名(函数名不带括号), 参数1),
gevent.spawn(指向的变量名(函数名不带括号), 参数2)
])