转载

BEAM和JVM之间的一些基本特征/架构差异是什么?

BEAM和JVM之间的一些基本特征/架构是什么?

>是的我知道:一个最初是围绕着java,另一个是围绕erlang建造的

>我理解JVM(有些),并希望比较他们的结构

>例如,我知道JVM有一个Global GC,而BEAM每个进程有一个

首先,梁是注册机,而不是堆栈机.像Prolog的WAM一样,它使用“X寄存器”,它们是正常寄存器(在C中实现为一个数组)和“Y寄存器”,它们是本地功能激活记录(“调用帧”)中的插槽的名称在栈上没有堆栈操作说明.

其次,有一些说明可以快速分配一堆堆内存,用于初始化堆上的元组和其他数据结构,用于选择元组元素等.JVM专注于对象,并具有隐藏的“新”操作内存分配和基本初始化的细节.

BEAM有一个减少进程的“减少计数器”的指令,并决定是否有时间让另一个进程运行.另一方面,JVM具有针对线程的同步指令.

一个重要的区别是,BEAM具有尾部调用指令,JVM缺少.

最后,对于BEAM和JVM,目标文件中使用的指令集只是一种传输格式. BEAM仿真器将文件中的指令重写为具有许多优化的特例指令(可从一个版本更改为另一个版本)的内部版本.或者,您可以编译为本机代码.大多数JVM都做同样的事情.

代码日志版权声明:

翻译自:http://stackoverflow.com/questions/2276370/what-are-some-fundamental-feature-architectural-differences-between-the-beam-and

原文  https://codeday.me/bug/20181016/291326.html
正文到此结束
Loading...