最近研究了一些Java平台的协程实现, 现做个总结.
由于现在标准的JDK仅支持线程栈, 只能等Loom项目加入JDK后才能支持协程栈, 所以现有Java实现的第三方协程本质上都是通过编译后期或运行前期修改字节码来实现的无栈协程, 只是有些库提供的API看起来像是有栈的.
常见的Java协程库有如下几个:
1. Javaflow
2. Tascalate Javaflow
3. Coroutines推荐.
4. Kilim
5. EA Async强烈推荐.
6. Kotlin协程: 这个其实不能算是Java的协程了, 不过毕竟跟Java兼容性比较好, 也是值得考虑的. 最重要的一点是它的开发团队不是上面几个项目可比的, 稳定性可靠性要好得多, 而且对协程相关的很多特性都有支持, 直接使用最底层的API可以达到最高的协程性能(参考:Kotlin与C#的协程性能对比). 因此对Kotlin不排斥的话也是强烈推荐的.
另外补充一下我理解的协程适用条件:
1. 一段流程(函数)的中间可能需要阻塞/暂停/打断;
2. 这段流程需要大规模(>100)的并发执行;
3. 这段流程如果手动切分成多段来异步执行非常麻烦.
同时满足以上3个条件才是真的适合使用协程, 小规模的并发就用线程好了, 线程切换在绝大多数场合都不会是性能问题. 到处都无脑使用协程只会自找麻烦, 当然有真正的有栈协程除外.
参考