博客
关于我
Lua 中的协程分享
阅读量:486 次
发布时间:2019-03-07

本文共 1858 字,大约阅读时间需要 6 分钟。

Lua里的协程是一个原来没见过的东西,Python的Gevent也是一个基于coroutine的python网络开发框架。性能据说很不错。

协程和一般多线程的区别是,一般多线程由系统决定该哪个线程执行,是抢占式的,而协程是由每个线程自己决定自己什么时候不执行,并把执行权主动交给下一个线程。协程是用户空间线程,操作系统其存在一无所知,所以需要用户自己去做调度,用来执行协作式多任务非常合适。

线程和协同程序的主要不同在于:在多处理器情况下,多线程程序同时运行多个线程;而协同程序是通过协作来完成,在任一指定时刻只有一个协同程序在运行,并且这个正在运行的协同程序只在必要时才会被挂起。这样Lua的协程就不能利用现在多核技术了。

Lua

协程有三个状态:挂起态(suspended)、运行态(running)、停止态(dead)。可以通过coroutine.status来查看协程出于神马状态。

创建一个协程需要调用coroutine.create 。它只接收单个参数,这个参数是 coroutine 的主函数。 create

函数仅仅创建一个新的coroutine 然后返回一个类型为thread的对象,并不会启动 coroutine

的运行。

>hxc=coroutine.create(function () print(“hi coroutine”)

end)

>print(type(hxc)) –>thread

>print(coroutine.status(hxc)) –>suspended

>coroutine.resume(co) –> hi coroutine

;函数coroutine.resume使协同程序由挂起状态变为运行态,执行完毕协程进入dead状态

>print(coroutine.status(hxc)) –>dead

调用 coroutine.resume 时,传入的第一个参数就是 coroutine.create 的返回值。这时,coroutine

从主函数的第一行开始运行。接下来传入 coroutine.resume 的参数将被传进 coroutine 的主函数。在

coroutine 开始运行后,运行到自身终止或是遇到一个

yield调用,这个yield函数是协程特别之处,它可以将正在运行的代码挂起。

hxc=coroutine.create(function ()

for

i=1,10 do

print(“iter”,

i)

coroutine.yield()

end

end)

执行这个协同程序,程序将在第一个yield处被挂起:

coroutine.resume(hxc) –> iter 1

print(coroutine.status(hxc)) –> suspended

执行

coroutine.resume(hxc) –> iter

2;resume激活被挂起的程序,将从函数yield的位置继续执行程序,直到再次遇到yield或程序结束。

Lua中协同可以通过resume-yield来交换数据。

1)通过resume把参数传递给协同的主程序。

hxc = coroutine.create(function (a,b)

print(“hxc”,

a,b,c)

end)

coroutine.resume(hxc, 1, 2) –> hxc 1 2

2)数据通过yield传给resume。true表明调用成功,true之后的部分,即是yield的参数。

hxc = coroutine.create(function (a,b)

coroutine.yield(a

+ b, a – b)

end)

print(coroutine.resume(hxc, 20, 10)) –> true 30

10

或者把resume的参数,会被传递给yield。

hxc = coroutine.create (function ()

print(“hxc”,

coroutine.yield())

end)

coroutine.resume(hxc)

coroutine.resume(hxc, 4, 5) –> hxc 4 5

协程的用途最明显的地方是需要访问某个异步的功能时,C语言常采用回调的方法:当异步完成时,回调脚本的一个已知的函数。如果程序执行到异步点时,跳回,当异步完成后,再回到跳回点继续执行。我的理解就是协程是把异步过程,当作同步处理。

转载地址:http://cmedz.baihongyu.com/

你可能感兴趣的文章
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>
NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
查看>>
NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_处理器介绍_处理过程说明---大数据之Nifi工作笔记0019
查看>>
NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_实际操作---大数据之Nifi工作笔记0020
查看>>
NIFI大数据进阶_Json内容转换为Hive支持的文本格式_实际操作_02---大数据之Nifi工作笔记0032
查看>>
NIFI大数据进阶_Json内容转换为Hive支持的文本格式_操作方法说明_01_EvaluteJsonPath处理器---大数据之Nifi工作笔记0031
查看>>
NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka消费者处理器_来消费kafka数据---大数据之Nifi工作笔记0037
查看>>
NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka生产者---大数据之Nifi工作笔记0036
查看>>
NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
查看>>
NIFI大数据进阶_NIFI监控功能实际操作_Summary查看系统和处理器运行情况_viewDataProvenance查看_---大数据之Nifi工作笔记0026
查看>>
NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
查看>>
NIFI大数据进阶_NIFI集群知识点_认识NIFI集群以及集群的组成部分---大数据之Nifi工作笔记0014
查看>>
NIFI大数据进阶_NIFI集群知识点_集群的断开_重连_退役_卸载_总结---大数据之Nifi工作笔记0018
查看>>
NIFI大数据进阶_使用NIFI表达式语言_来获取自定义属性中的数据_NIFI表达式使用体验---大数据之Nifi工作笔记0024
查看>>
NIFI大数据进阶_内嵌ZK模式集群1_搭建过程说明---大数据之Nifi工作笔记0015
查看>>
NIFI大数据进阶_外部ZK模式集群1_实际操作搭建NIFI外部ZK模式集群---大数据之Nifi工作笔记0017
查看>>
NIFI大数据进阶_实时同步MySql的数据到Hive中去_可增量同步_实时监控MySql数据库变化_操作方法说明_01---大数据之Nifi工作笔记0033
查看>>
NIFI大数据进阶_实时同步MySql的数据到Hive中去_可增量同步_实时监控MySql数据库变化_操作方法说明_02---大数据之Nifi工作笔记0034
查看>>
NIFI大数据进阶_离线同步MySql数据到HDFS_01_实际操作---大数据之Nifi工作笔记0029
查看>>
NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
查看>>