Java的Actor框架--kilim
来源:互联网 发布:cdn网络拓扑图 编辑:程序博客网 时间:2024/05/21 11:25
除了Akka以外,另外一个将类似Erlang和Scala的Actor的并发模型引入Java的开源框架:kilim/kilim - GitHub,其使用了一种mailbox跨线程共享内存,没有锁或同步。
消息消费者代码如下,监听mailbox:
public class Calculator extends Task{ private Mailbox<calculation> mailbox; public Calculator(Mailbox<calculation> mailbox) { super(); this.mailbox = mailbox; } @[author]Override[/author] public void execute() throws Pausable, Exception { while (true) { Calculation calc = mailbox.get(); // blocks if (calc.getAnswer() == null) { calc.setAnswer(calc.getDividend().divide(calc.getDivisor(), 8, RoundingMode.HALF_UP)); System.out.println("Calculator determined answer"); mailbox.putnb(calc); } Task.sleep(1000); } }}
消息发生者,向mailbox发送消息:
public class DeferredDivision extends Task { private Mailbox<calculation> mailbox; public DeferredDivision(Mailbox<calculation> mailbox) { super(); this.mailbox = mailbox; } @[author]Override[/author] public void execute() throws Pausable, Exception { Random numberGenerator = new Random(new Date().getTime()); MathContext context = new MathContext(8); while (true) { System.out.println("I need to know the answer of something"); mailbox.putnb(new Calculation( new BigDecimal(numberGenerator.nextDouble(), context), new BigDecimal(numberGenerator.nextDouble(), context))); Task.sleep(1000); Calculation answer = mailbox.getnb(); // no block if (answer != null && answer.getAnswer() != null) { System.out.println("Answer is: " + answer.printAnswer()); } } }}
需要使用Ant调用 Kilim's weaver(byte code enhancer):
<target name="weave" depends="compile" description="handles Kilim byte code weaving">
<java classname="kilim.tools.Weaver" fork="yes">
<classpath refid="classpath">
<arg value="-d">
<arg value="./target/classes">
<arg line="./target/classes">
</arg></arg></arg></classpath></java>
</target>
客户端测试代码:
Mailbox<calculation> sharedMailbox = new Mailbox<calculation>(); Task deferred = new DeferredDivision(sharedMailbox); Task calculator = new Calculator(sharedMailbox); deffered.start(); calculator.start();
在"events vs. threads"争论提及两个问题:线程是重量的;其次线程范式隐式的和共享内存锁联系在一起,导致性能陷阱;而Kilim 试图证明线程也可以和状态机一样轻量,甚至提供一个自动的线程stack管理特性(也就没有必要的 "return to the mainloop" 返回主循环的编程习惯).
0 0
- Java的Actor框架--kilim
- Kilim框架的Actor并发模型
- Kilim框架的Actor并发模型
- Kilim:actor模型和消息传递的Java实现
- Java协程框架--Kilim源码分析
- Java协程框架--Kilim工作原理
- Java协程框架--Kilim常见问题解答
- Java协程框架--Kilim常见问题解答
- Java协程框架--Kilim工作原理
- Java协程框架--Kilim源码分析
- 下一代的 Actor 模型框架 Proto Actor
- Java协程框架--Kilim框架Fiber浅析
- Java协程框架--Kilim框架Fiber浅析
- Java协程框架----Kilim实现机制解析
- Java协程框架-Kilim字节码剖析
- Java协程框架----Kilim实现机制解析
- Java协程框架-Kilim字节码剖析
- java的actor库
- Linux下源码安装php7.0.6
- 【cocos2d-x从c++到js】14:注册函数
- Android热修复实践应用--AndFix
- CC2541之电池电量服务
- Web 服务编程,REST 与 SOAP 比较
- Java的Actor框架--kilim
- [树状数组套权值线段树] BZOJ 1901 Zju2112 Dynamic Rankings
- Git常用命令
- androdi studio 更新方法
- SQL Server创建存储过程
- 邱似峰:网易视频云如何实现应用加速
- 【HTTP】Fiddler(三)- Fiddler命令行和HTTP断点调试
- BZOJ3545 [ONTAK2010]Peaks
- 【cocos2d-x从c++到js】15:傀儡构造函数