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