- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
Scala 中那些与 Future 相关的类和特征之间有什么联系,为什么它们散布在不同的包中?
我找到了那些:
abstract class scala.actors.Future
object scala.actors.Futures
trait/object scala.collection.parallel.FutureThreadPoolTasks
trait scala.concurrent.FutureTaskRunner
trait scala.parallel.Future (the package consists of only this file...)
最佳答案
scala.actors._
abstract class Future
首先,让我们看看文档是怎么说的:
A function of arity 0, returing a value of type T that, when applied, blocks the current actor (Actor.self) until the future's value is available.
sender
引用)并且您需要对已发送消息的回复,您有两种选择:
A future can be queried to find out whether its value is already available without blocking [using "isSet"].
Future
本身是一个
abstract class
,由
private class FutureActor
扩展.最后一个类是实际实现
Future
的类。 - 功能。
object Futures
object Futures
到目前为止还没有那么有趣,因为它只是“操作 future 的方法”的容器,方便的工厂方法
future
它异步评估传递的块,返回表示结果的 future 。一个小例子是这样的:
import scala.actors.Futures
val f = Futures.future {
println("Start: inside block")
val s = System.currentTimeMillis
while(System.currentTimeMillis < (s + 1000)) {
// Simulate computation
}
println("Start: end of block")
42
}
println("After future")
println(f())
println("The end")
Start: inside block
After future
Start: end of block
42
The end
future
-call 不会阻塞以下代码,直到您实际尝试检索 future 的值(请注意,输出是
non-deterministic 。
After future
也可能出现在输出的开头)。
scala.collection.parallel
Par
开头的:
(1 to 10).par.map { b => print(b + " "); b * b }
3 1 6 2 7 4 5 9 10 8
# => (1, 4, 9, 16, 25, 36, 49, 64, 81, 100)
trait FutureThreadPoolTasks
FutureThreadPoolTasks
trait 扩展了
Tasks
trait,所以让我们先来看看那个。特质上面的评论说:
A trait that declares task execution capabilities used by parallel collections.
Tasks
中找到的方法来看trait,一个 Task 代表一个需要计算的工作单元。根据问题是否可以进一步分割,如果有更多可用资源,任务可以通过创建更多任务来进一步拆分任务。
FutureThreadPoolTasks
trait 本身只是一种计算任务的方法,它使用
java.util.concurrent.Future
类为其同步,即它
不使用
scala.actors.Future
!从来源:
An implementation of tasks objects based on the Java thread pooling API and synchronization using futures.
object FutureThreadPoolTasks
FutureThreadPoolTasks
特质使用。
scala.concurrent
scala.parallel
trait Future
scala.parallel
包仅包含此特征。据我所知,这将与
Future
有关。不使用的实现
Actors
,但这只是一个猜测。特征的签名如下
trait Future[@specialized +R] extends (() => R)
apply
和
isDone
.我的猜测是
isDone
,就像
scala.actors.Future.isSet
, 应该是一个非阻塞调用,以查看是否已经计算了该值,而
apply
方法应该用于实际检索值。
关于scala - Scala 中多个 Futures 的奇怪案例,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6229468/
我有这种来自 Google map 自动完成的奇怪行为(或者我可能错过了某事)...想法?奇怪的: 您在输入中输入某物,例如“伦敦” 您按 [ENTER] 你按下 [CLEAR] 按钮 你点击进入'输
这段代码与《Learning Java》(Oracle Press Books)一书中的代码完全一样,但它不起作用。我不明白为什么它不起作用,它应该起作用。我用 OpenJDK 和 Sun JDK 7
示例 1 中究竟发生了什么?这是如何解析的? # doesnt split on , [String]::Join(",",("aaaaa,aaaaa,aaaaa,aaaaa,aaaaa,aa
我需要获得方程式系统的解决方案。为此,我使用函数sgesv_()。 一切都很好,它使我感到解决方案的正确结果。 但是我得到一个奇怪的警告。 警告:从不兼容的指针类型传递'sgesv_'的参数3 我正在
我目前在制作动画时遇到一个奇怪的问题: [UIView animateWithDuration:3 delay:0
alert('works'); $(window).load(function () { alert('does not work'); });
我的代码: public class MyTest { public class StringSorter implements Comparator { public
我正在学习 JavaScript。尝试理解代码, function foo (){ var a = b = {name: 'Hai'}; document.write(a.name +''
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
这按预期工作: [dgorur@ted ~]$ env -i env [dgorur@ted ~]$ 这样做: [dgorur@ted ~]$ env -i which date which: no
struct BLA { int size_; int size()const{ return size_; } } int x; BLA b[ 2 ]; BLA * p = &b[
我有以下代码: #test img {vertical-align: middle;} div#test { border: 1px solid green; height: 150px; li
我想大多数使用过 C/C++ 的人都对预处理器的工作原理有一定的直觉(或多或少)。直到今天我也是这么认为的,但事实证明我的直觉是错误的。故事是这样的: 今天我尝试了一些东西,但我无法解释结果。首先考虑
我想为 TnSettings 做 mock,是的,如果通过以下方法编写代码,它就可以工作,问题是我们需要为每个案例编写 mock 代码,如果我们只 mock 一次然后执行多个案例,那么第二个将报告异常
我的项目中有以下两个结构 typedef volatile struct { unsigned char rx_buf[MAX_UART_BUF]; //Input buffer over U
Regex rx = new Regex(@"[+-]"); string[] substrings = rx.Split(expression); expression = "-9a3dcb
我的两个应用程序遇到了一个奇怪的问题。这是设置: 两个 tomcat/java 应用程序,在同一个网络中运行,连接到相同的 MS-SQL-Server。一个应用程序,恰好按顺序位于 DMZ 中可从互联
我目前正在与 Android Api Lvl 8 上的 OnLongClickListener 作斗争。 拿这段代码: this.webView.setOnLongClickListener(new
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况相关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
只是遇到了奇怪的事情。我有以下代码: -(void)ImageDownloadCompleat { [self performSelectorOnMainThread:@selector(up
我是一名优秀的程序员,十分优秀!