Erlang特性:
并发性 - Erlang支持超大量级的并发进程,并且不需要 *** 作系统具有并发机制。
分布式 - 一个分布式Erlang系统是多个Erlang节点组成的网络(通常每个处理器被作为一个节点)
健壮性 - Erlang具有多种基本的错误检测能力,它们能够用于构建容错系统。
软实时性- Erlang支持可编程的“软”实时系统,使用了递增式垃圾收集技术。
热代码升级-Erlang允许程序代码在运行系统中被修改。旧代码能被逐步淘汰而后被新代码替换。在此过渡期间,新旧代码是共存的。
递增式代码装载-用户能够控制代码如何被装载的细节。
外部接口-Erlang进程与外部世界之间的通讯使用和在Erlang进程之间相同的消息传送机制。
Fail-fast(中文译为速错),即尽可能快的暴露程序中的错误。
面向并发的编程(COP concurrency-oriented programming)
函数式编程
动态类型
及早求值或严格求值
脚本语言
(1)erlang应用程序启动过程中,还可以分阶段启动。在erlang应用程序的资源文件*.app可以定义分步骤启动。
*.app中的start_phase字段的值可以指定多个参数分别启动
start_phase的调用时机是在start之后调用的。
(2)erlang是一种分布式语言,在启动应用程序时感觉与C/C++/Java/python都有很大的区别,因为没有main函数
其实这是一个已经可以发布的应用程序与非发布式程序的区别。
如果是一个已经发布的应用程序,安装后启动时,还是有main函数的。
类似Java,Java JVM是用C语言开发的,erlang虚拟机也是用C开发的,非发布的应用程序启动,
诸如:application:start(appName),这是在虚拟机里启动的。
erl其实是个shell脚本,在erl脚本中它实际调用的是erlexec,这个程序的入口是erlexec.c。
erlexec的main函数首先解析命令行传入的参数和环境变量,然后寻找beam可执行文件,
然后就通过execv运行Beam虚拟机,erlexec就是个加载器,在这个过程中就会将命令行参数传递给虚拟机中的init进程。
这个时候发现erlang就像是一个 *** 作系统,linux *** 作系统中也有init进程。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)