- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
给定一个执行上下文和一个线程池,akka/scala Actor 是如何安排/实现的?
最佳答案
我对这个话题困惑了很长时间。我假设线程和参与者之间存在某种关系。对于每个 Actor ,都有一个线程来承载它,所以我在想。每个线程可能有几个参与者在协作多任务模式下工作。
文档侧重于使用,并简单地涵盖了内部架构。您只需扩展 Actor
上课,你会得到一个工作 Actor 。所以我试图猜测如何做到这一点,并想象每个 Actor
有生命周期,比如异步等待消息队列,然后处理消息,然后开始。
那是一个完全错误的假设。虽然文档说“ Actor 生命周期”,但这并不意味着 Actor
生命周期。提到的 Actor 是一个概念,而不是实现 Actor
的实际对象。类(class)。该对象被动地驻留在 java 堆中。
为了给这个概念注入(inject)活力,需要一群真正的 worker 参与的协调工作。它的核心是调度员。它包含所有参与者、线程和消息。当资源变得可用并且有可用于处理的消息时,调度程序激活。它需要一个适当的 Actor
对象,将其接收方法包装在 runnable 中,并将其传递给备用线程。因此,对象没有生命周期,只有来自参与者系统的偶尔方法调用。
当你想到它时,它比我之前假设的方案更有意义。但是我很难从可用的文档中推断出它。它是由经验丰富的并发程序员编写的。持有actor类与其背后的actor概念的区别。他们知道 Actor 系统的调度程序就像操作系统的任务调度程序。因此,他们很快就切入主题并描述了每个人都熟悉的概念的各种口味和实现。
但这对新手来说并不容易。他不熟悉参与者系统上下文中的调度程序模式。我试图用谷歌搜索“调度程序模式”,它显示了与参与者系统无关的定义。
我很容易找到 double dispatch 、多调度和其他 OOP 主题。我发现了类似于 Akka 的路由器 message dispatcher 的东西. Actor 消息调度程序可能有一个不错的描述,但并不容易找到。
我希望我已经消除了误解。
关于multithreading - akka actor 如何在底层线程上实现?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20673206/
我有以下功能: function addChange(result, bill) { for (var i=0;i
这是网站: www.wearethefirehouse.com/phasetest 如果您慢慢滚动,您会注意到一旦菜单栏完全不透明,nav li 元素就会全部从 Enzo 300 跳起来(如在没有导航
美好的一天。对于当前的项目,我需要知道数据类型如何表示为字节。例如,如果我使用: long three = 500;var bytes = BitConverter.GetBytes(three);
请解释 JVM 是如何在底层收集 ThreadDump 的。 我不明白它如何收集脱离 CPU 的线程的堆栈跟踪(等待磁盘 IO、网络、非自愿上下文切换)。 例如,linux perf 仅收集有关 on
开始学习 R,如果能帮助我理解 R 如何决定不同向量的类别,我将不胜感激。我初始化 vec <- c(1:6)当我执行 class(vec)我得到“整数”。为什么它不是“数字”,因为我认为 R 中的整
我有一个透明的 UIView,几乎覆盖了整个屏幕。我在顶部留下了 50 像素。它是 View Controller View 的 subview 。 在UIView下面有一个继承自UIView的MyV
我很好奇对象是如何在 Nodejs 中显示的,在本例中是 Promise。使用 console.log(promiseObject) 时,输出的类型为 {状态:待处理} 这对我来说似乎很奇怪,因为在该
当您在 Windows Azure 中使用表服务 API 时,幕后到底在做什么?我想我在某处读到这没有使用 SQL Server。它是否执行哈希表,然后过滤器真的像映射/减少操作一样运行?我对这些东西
如何查看函数 concat 中的代码?它是如何做的?有没有人有代码的副本或在浏览器控制台中查看它的方法? console.dir 不给我访问权限 console.dir(Array.prototype
我是 C++ 的新手,所以如果这个问题的答案显而易见,我深表歉意。 我一直在编写 STL 样式的自定义数据结构,以此来提高我的技能。 (我实际上也确实需要这种结构,但出于学习目的,我有点过分了。) 此
我正在尝试使用 log4j appender 将日志发送到 GrayLog2 (log4j2-gelf)。所以我将我的依赖项添加到我的 pom.xml 配置 log4j2.xml 来配置我的 appe
我正在使用带有 vector 的 priority_queue 作为底层容器。但是我希望堆的大小非常大。我知道动态 vector 容量调整大小的问题。所以我正在寻找方法来为我的priority_que
我有一个 SqlDataAdapter,它填充了 21 行数据(4 列)。驱动它的 sproc 在几秒钟内在 SQL Mgmt Studio 中返回,但 .Fill() 需要 5 分钟。 Ar
我想实现一个屏幕控制按钮,按下它可以作为 GUI 交互的修饰符。 这对于 MouseArea 是不可能的,因为该 API 只能处理一个鼠标区域中的一个触摸点。 该限制不适用于 MultiPointTo
我试图将图像和 div 层置于包含 div 的中心,但到目前为止我无法让它从列的左侧移动。我尝试了几种不同的方法,但就是无法让它移动。即使 margin auto 技巧也不起作用,我怀疑这是因为 bo
需要明确的是,我不是在询问 HDFS 中的权限设置,而是在 ext3 中或在 HDFS 运行于其上的各个数据节点机器上使用的任何文件系统中。 p> 我知道我们设置了 sudo chown hduser
我在服务器上创建了一个枚举,其中手动设置了整数值,而不是默认从 0 开始递增 public enum UserType { Anonymous = 0, Customer = 10,
如果显示框架图像,我们能否使以下 Google map 具有交互性。 Vie
我有一个顶部有自定义状态栏的布局 [在 Apple 的状态栏下方],然后是 UIScrollview 在中间部分从左到右分页,然后我有一个 UIView 底部有一些自定义按钮。一个简单的三 Pane
事情是这样的。我有一个 MVC 操作,在该操作上,我应用了自定义 ActionFilterAttribute 来使反序列化工作。现在,我想要做的是根据在此 View 中设置的 ViewBag.Titl
我是一名优秀的程序员,十分优秀!