为什么全局ExecutionContext不是未来块中的默认参数?

时间:2013-08-20 11:34:31

标签: scala future

当您使用Futures或Actors响应编写一些高度并发的代码并且您手动导入ExecutionContext.Implicits.global时,这真的很烦人。试图找到一些很好的解释,为什么它不作为默认参数,例如Strategy中的Scalaz Concurrent done。这将非常有用,而不是在代码中插入/删除所有这些导入。或者我错过了一些逻辑?

1 个答案:

答案 0 :(得分:10)

总的趋势似乎是要求用户明确地导入诸如implicits,额外运算符或DSL之类的东西。我认为这是一件好事,因为它使事情变得不那么“神奇”,更容易理解。

但是没有什么能阻止你为你的代码定义一个包的隐式值。请注意,如果默认情况下始终导入隐式ExecutionContext,则无法执行此操作。

在包对象中:

package object myawsomeconcurrencylibrary {
  implicit def defaultExecutionContext = scala.concurrent.ExecutionContext.global
}

在同一个包中的任何类中:

package myawsomeconcurrencylibrary

object Bla {
  future { ... } // implicit from package object is used unless you explicitly provide your own
}