erlang是什么啊。?

erlang是什么啊。?,第1张

Erlang是一种通用的面向并发的编程语言,它由瑞典电信设备制造商爱立信所辖的CS-Lab开发,目的是创造一种可以应对大规模并发活动的编程语言和运行环境。

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进程。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12018532.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-20
下一篇 2023-05-20

发表评论

登录后才能评论

评论列表(0条)

保存