当您使用Futures或Actors响应编写一些高度并发的代码并且您手动导入时,这真的很烦人ExecutionContext.Implicits.global.试图找出为什么喜欢它它不是做成一个默认参数,一些很好的说明完成与Strategy在Scalaz Concurrent.这将非常有用,而不是在代码中插入/删除所有这些导入.或者我错过了一些逻辑?
Rüd*_*ehn 10
总的趋势似乎是要求用户明确地导入诸如隐含,额外运营商或DSL之类的东西.我认为这是一件好事,因为它使事情变得不那么"神奇",更容易理解.
但是,没有什么可以阻止您为代码定义程序包范围的隐式值.请注意,如果默认情况下始终导入隐式ExecutionContext,则无法执行此操作.
在包对象中:
package object myawsomeconcurrencylibrary {
implicit def defaultExecutionContext = scala.concurrent.ExecutionContext.global
}
Run Code Online (Sandbox Code Playgroud)
在同一个包中的任何类中:
package myawsomeconcurrencylibrary
object Bla {
future { ... } // implicit from package object is used unless you explicitly provide your own
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1372 次 |
| 最近记录: |