标签:style os 使用 sp java strong on 数据 问题
从Erlang进程看协程思想
多核慢慢火了以后,协程类编程也开始越来越火了。比较有代表性的有Go的goroutine、Erlang的Erlang进程、Scala的actor、windows下的fibre(纤程)等,一些动态语言像Python、Ruby、Lua也慢慢支持协程。
其实我们听过协程相关很多名词,下面大致来解释一下:
也就是说,协程具有以下特点:
基本能满足以上特点的我们都可以称其为协程(coroutine)。
但不同语言却有不同实现方式,其中主要有以erlang为代表的 actor model,还有以Go为代表的Coroutine。
Go那边不太熟悉,不过主要就是协程间通信方式和yield主动让出CPU操作,这些在Python、Ruby等中也有实现。
Erlang以及Scala主要采取的是一种 actor model,也叫面向actor的编程。主要遵循以下特点:
从他的特性看来,Actor是一种比普通Coroutine更彻底的一种面向并发的编程模型。在设计actor model的程序时,开发者只需要考虑如何利用并发特性使自己程序的并发性能更好,而不需要去考虑锁、冲突、不一致性等问题。
标签:style os 使用 sp java strong on 数据 问题
原文地址:http://www.cnblogs.com/lhfcws/p/4148227.html