其他分享
首页 > 其他分享> > Go 通道(channel)3

Go 通道(channel)3

作者:互联网

Futures 模式

Futures 模式是指,当需要用到某个值之前,需要先对该值进行计算,这时候可以将该值的计算放到另一个处理器计算该值,当使用该值时已经计算完毕了。

例如,最终需要 part1part2 的和,求和之前part1part2都需要处理一些自己的事情,而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