14.9 实现 Futures 模式

    Futures 模式通过闭包和通道可以很容易实现,类似于生成器,不同地方在于 Futures 需要返回一个值。

    在这个例子中,ab 的求逆矩阵需要先被计算。那么为什么在计算 的逆矩阵时,需要等待 a 的逆计算完成呢?显然不必要,这两个求逆运算其实可以并行执行的。换句话说,调用 Product() 函数只需要等到 a_inv 和 的计算完成。如下代码实现了并行计算方式:

    当开发一个计算密集型库时,使用 Futures 模式设计 API 接口是很有意义的。在你的包使用 Futures 模式,且能保持友好的 API 接口。此外,Futures 可以通过一个异步的 API 暴露出来。这样你可以以最小的成本将包中的并行计算移到用户代码中。(参见参考文件 18:http://www.golangpatterns.info/concurrency/futures