python迭代器与生成器以及并发

什么是迭代器

"""
什么叫迭代器--->实现了迭代器协议的对象
迭代器协议---->两个魔术方法
__iter__--->返回迭代器对象
__next__--->从迭代器获取下一个迭代值
"""


class FibIter:

    def __init__(self, max_count):
        self.a, self.b = 0, 1
        self.cur_count = 0
        self.max_count = max_count

    def __iter__(self):
        return self

    def __next__(self):
        if self.cur_count < self.max_count:
            self.a, self.b = self.b, self.a + self.b
            self.cur_count += 1
            return self.a

        raise StopIteration


F = FibIter(20)
for value in F:
    print(value)

什么是生成器

"""
什么叫生成器 -> 迭代器语法的升级版
"""


def fib(max_count):
    a, b = 0, 1
    for _ in range(max_count):
        a, b = b, a + b
        yield a


f = fib(20)
for value in f:
    print(value)

协作并发

"""
并行 / 并发   --->  多任务在同时执行
    ~多线程---->GIL---->无法使用多核特性
    ~多进程---->启动多个Python解释器来执行一个代码--->可以利用CPU的多核特性
        --->一般写爬虫不适用多进程,因为爬虫是I/0密集型任务
"""
"""
协程  ---> co-routine  --> 相互协作的子程序
生成器经过预激活就可以成为协程(跟其他子程序进行协作 --->  协作式并发)
"""


def calc_average():
    total, counter = 0, 0
    avg_value = None
    while True:
        # 子程序负责计算平均值并产出
        curr_value = yield avg_value
        total += curr_value
        counter += 1
        avg_value = total / counter


def main():
    calc = calc_average()
    # 协作 主程序负责提供数据
    # 第一次send是为了将生成器预激活为协程
    print(calc.send(None))
    print(calc.send(20))
    print(calc.send(30))
    print(calc.send(40))


if __name__ == '__main__':
    main()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

azured_xu

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值