当您使用Futures或Actors响应编写一些高度并发的代码并手动导入时,这确实很烦人ExecutionContext.Implicits.global
。试图找到一些很好的解释为什么喜欢它它不是做成一个默认参数,完成与Strategy
在Scalaz Concurrent
。这将非常有帮助,而不是在代码中插入/删除所有这些导入。还是我缺少一些逻辑?
总体趋势似乎是要求用户显式导入诸如隐式,额外的运算符或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
}
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句