标签:该值 int Futures part1 part2 func Go channel 通道
Futures 模式
Futures 模式是指,当需要用到某个值之前,需要先对该值进行计算,这时候可以将该值的计算放到另一个处理器计算该值,当使用该值时已经计算完毕了。
例如,最终需要 part1
与 part2
的和,求和之前part1
和part2
都需要处理一些自己的事情,而part2
为什么要等待part1
做完再做呢 ? 他们其实可以并行的!
part1 := 2
part2 := 3
part1 = func (i int) {i + 3}(part1) // 或做其他事情的函数
part2 = func (i int) {i + 5}(part1) // 或做其他事情的函数
sum := part1 + part2
修改代码为 Futures 模式:
func add_value(p, a int) <-chan int { //返回只读数据的通道
future := make(chan int)
go func() {
future <- p + a
}()
return future
}
part1 := 2
part2 := 3
part1 = <-add_value(part1, 3)
part2 = <-add_value(part2, 5)
sum := part1 + part2
标签:该值,int,Futures,part1,part2,func,Go,channel,通道 来源: https://www.cnblogs.com/magower/p/16530338.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。