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