内容简介:程序输出如下,
package main import ( "fmt" ) func main() { generator := func(done <-chan interface{}, args ...int) <-chan int { results := make(chan int) go func() { defer close(results) for _, v := range args { select { case <-done: return case results <- v: } } }() return results } multiply := func(done <-chan interface{}, intStream <-chan int, multiplier int) <-chan int { results := make(chan int) go func() { defer close(results) for i := range intStream { select { case <-done: return case results <- i * multiplier: } } }() return results } add := func(done <-chan interface{}, intStream <-chan int, additive int) <-chan int { results := make(chan int) go func() { defer close(results) for i := range intStream { select { case <-done: return case results <- i + additive: } } }() return results } done := make(chan interface{}) defer close(done) for v := range multiply(done, add(done, multiply(done, generator(done, 1, 2, 3, 4), 2), 1), 2) { fmt.Println(v) } }
程序输出如下,
image.png
以上所述就是小编给大家介绍的《Golang pipline的最佳实践--使用channel》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 使用 Spell 实践深度学习,几乎零配置开始使用
- OpenGL 之 帧缓冲 使用实践
- 使用 Docker 安装 Zabbix 实践
- Logback最佳实践和使用指导
- Git子模块功能使用实践
- 网易 MyRocks 使用和优化实践
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
ODPS权威指南
李妹芳 / 人民邮电出版社 / 2014-12 / 69元
ODPS(Open Data Processing Service)是阿里巴巴自主研发的海量数据处理和分析的服务平台,主要应用于数据分析、海量数据统计、数据挖掘、机器学习和商业智能等领域。目前,ODPS不仅在阿里内部得到广泛应用,享有很好的口碑,正逐步走向第三方开放市场。 本书是学习和掌握ODPS的权威指南,作者来自阿里ODPS团队。全书共13章,主要内容包括:ODPS入门、整体架构、数据通......一起来看看 《ODPS权威指南》 这本书的介绍吧!