提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
转帖|使用教程|编辑:黄竹雯|2019-04-15 11:18:30.000|阅读 579 次
概述:浅谈Python中的协程及利用协程代替多线程及多进程并发编程,与大家分享协程的魅力。
#慧都22周年庆大促·界面/图表报表/文档/IDE/IOT/测试等千款热门软控件火热促销中>>
相关链接:
协程定义说的清楚明了的文章不是很多,手头上有几本Python相关的书籍,其中《流畅的Python》一书中解释协程的定义是小编认为最简单明了的。
乍看生成器和协程长的可真像,因为都用到了yield关键字,那么问题来了,如何区分二者?
def cd(n):
print("Counting down from %s" % n)
while n > 0:
yield n
n -= 1
c = cd(10)
next(c)
for i in c :
print(i,end=' ')
上面是一个典型的生成器函数,我们稍加变化使之成为协程。
def cd1():
n = yield
while n > 0:
print("Counting down from %s" % n)
n -= 1
c1 = cd1()
next(c1)
c1.send(10)
#运行到这里应该抛出一个异常
生成器和协程的不同有没有看出来?很明显的有两处:
通过运行结果我们可以到最后抛出了一个异常StopIteration,然后结束了这个协程。我们可以考虑一下:用装饰器省略掉next()这步,然后捕获抛出的异常,再关闭掉协程函数。
from functools import wraps
def coroutine(func):
@wraps(func)
def primer(*args, **kwargs):
gen = func(*args,**kwargs)
next(gen)
return gen
return primer
@coroutine
def cd2():
n = yield
while n > 0:
print("Counting down from %s" % n)
n -= 1
try:
cd2().send(10)
except Exception as e:
print('协程任务终止')
带上了装饰器,就更简便一些了,最后捕获异常,就可以结束这个协程了。
我们想用生成器(协程)作为系统线程的替代方案来实现并发。协程有时也称为用户级线程或绿色线程。————引自《Python Cookbook》 这里的协程用到了asyncio模块,利用asyncio模块实现了一个协程的并发。关于asyncio的实现原理,之后再研究一下。
import asyncio
import time
import threading
def tn(func):
'''定义一个程序运行时间计算函数'''
def wrapper(*args, **kwargs):
start = time.time() # 起始时间
func(*args, **kwargs) # 要执行的函数
end = time.time() # 结束时间
print('程序运行时间:{:.2f}ms'.format((end-start)))
return wrapper
def loop1(tname):
print(tname+"循环loop1打印时间======" + time.ctime())
time.sleep(1)
# @asyncio.coroutine
async def loop2(tname):# async等同于@asyncio.coroutine
print(tname+"循环loop1打印时间======" + time.ctime())
# yield from asyncio.sleep(1)
await asyncio.sleep(1) # 等同于yield from
@asyncio.coroutine
def loop3(tname):# async等同于@asyncio.coroutine
print(tname+"循环loop1打印时间======" + time.ctime())
yield from asyncio.sleep(1)
# await asyncio.sleep(1) # 等同于yield from
@tn
def main():
print('多线程任务开始执行=====')
threads = []#定义一个线程队列
for i in range(5):
t = threading.Thread(target=loop1, args=("thread"+str(i),))
threads.append(t)
for i in range(5):
threads[i].start()
for i in range(5):
threads[i].join()
#协程并发测试
print('协程并发测试开始======')
loop = asyncio.get_event_loop()# 获取一个event_loop
#任务列表
tasks = [
asyncio.ensure_future(loop2('11111')),
asyncio.ensure_future(loop2('22222')),
asyncio.ensure_future(loop2('33333')),
asyncio.ensure_future(loop3('44444')),#loop3
asyncio.ensure_future(loop3('55555'))]#loop3
loop.run_until_complete(asyncio.wait(tasks))
loop.close()
if __name__ == '__main__':
main()
上边这组代码稍稍有点乱,可能你需要认真的理下思绪,对比一下结果,你会发现虽然后边执行的代码没有利用多线程,但打印结果上的时间和多线程的执行结果是一样的。 这就是协程的魅力所在,一条线程搞定多线程任务。
【专业Python IDE推荐】——PyCharm (正版低至¥1068):
PyCharm 是一款Python IDE,其带有一整套可以帮助用户在使用Python语言开发时提高其效率的工具。此外,该IDE提供了一些高级功能,以用于Django框架下的专业Web开发。
PyCharm基础教程推荐:
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@hmdbvip.cn




本文主要介绍如何在MVVM应用程序中使用虚拟源,欢迎下载最新版组件体验!
Aspose.Slides for Java使用户能够轻松地操作幻灯片、添加注释和转换文件。其易用性和集成能力提高了工作效率,使开发人员能够专注于更关键的任务。
在嵌入式软件测试领域,对交叉编译代码进行单元测试是一大挑战。Parasoft C/C++test作为专业的C/C++测试工具,能够与劳特巴赫Trace32调试器深度集成。下面会详细介绍如何在C++test中配置Trace32调试器,实现对PowerPC架构程序的单元测试,涵盖环境设置、项目导入到测试执行的全过程。
本文将为大家介绍如何使用DevExpress WinForms数据网格控件实现摘要文本的格式化,欢迎下载最新版组件体验!
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@hmdbvip.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢
永利最大(官方)网站 