与通常的“非本机”编译相比,使用选项编译 Erlang.erl
源代码有哪些限制/约束?+native
问问题
1498 次
1 回答
11
BEAM 仿真器提供的跟踪、断点和单步执行功能在本机编译代码中不可用。还有一个限制是,当您加载同一模块的较新版本时,本机代码并没有真正从内存中卸载。(如果您有一个长时间运行的系统,您不断升级模块或动态生成和编译模块,这可能是一个问题。)
此外,在本机代码和仿真 BEAM 代码之间跳转时会有少量开销,因此您应该避免在速度很重要的紧密循环中进行这种模式切换。最好将所有密切相关的模块编译为本机,如果可能的话也编译最重要的标准库模块。
最后,虽然原生编译器经过了很好的测试,但 HiPE 中出现编译器错误的概率比 BEAM 仿真器 C 代码中的错误要高一些(尽管可能不高于 GCC 中的错误),所以你可以运行系统段错误的风险更大。不过,这几天很少见了。
总而言之,目前可能不建议使用原生编译的主要地方是独立产品(例如您交付给客户的黑盒服务器),其中稳定性、远程可调试性和低内存使用率是您的主要目标关注和计算速度通常不是。
于 2010-02-06T10:07:53.550 回答