多线程和协程 之协程的理解

本文介绍了协程的概念及其与子程序的区别,强调了协程在执行效率上的优势,因为它避免了线程切换的开销。协程允许在一个线程内实现并发执行,通过在子程序内部中断并切换到其他子程序,同时无需多线程的锁机制。此外,文章提到了在多核CPU环境下,通过多进程+协程的方式可以充分利用硬件资源。greenlet和gevent模块被提及用于简化协程的管理和切换。最后,提出了一个计算场景,展示了如何通过协程实现大规模并发执行。
摘要由CSDN通过智能技术生成

协程,又称微线程,纤程
先讲子程序:子程序,或者称为函数,在所有语言中都是层级调用,比如A调用B,B在执行过程中又调用了C,C执行完毕返回,B执行完毕返回,最后是A执行完毕。 统称为函数执行
所以子程序调用是通过栈实现的,一个线程就是执行一个子程序,子程序调用总是一个入口,一次返回,调用顺序是明确的。而协程的调用和子程序不同。
由此出现的不同点:协程看上去也是子程序,但执行过程中,在子程序内部可中断,然后转而执行别的子程序,在适当的时候再返回来接着执行,如下代码所示:

def A():
    print('1')
    print('2')
    print('3')

def B():
    print('x')
    print('y')
    print('z')

打印结果为:

1
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值