一位Erlang程序猿的自白

一位Erlang程序猿的自白

大家好,又见面了,我是全栈君,祝每个程序员都可以多学几门语言。











Erlang不能错过的盛宴

(快步进入Erlang的世界)

作者:成立涛 (litaocheng@gmail.com)

作为程序猿,我们以前闻听非常多“业界动态”,“技术革新”,以前接触非常多“高手箴言”,“权威推荐”。这些正确与否,都已成过去!

如今,让我们迎接Erlang盛宴!

一、经历

200711月在koders.com搜索代码时,发现*.erl格式的源文件,感叹开发语言的花样百出,此时,我认为erlang是一个丑陋的小家伙,看名字就没有对它提起多少兴趣。

2008年初的时候,公司的项目开发中,我有缘认识了ejabberd,一个採用Erlang开发的开源jabberserver。我開始为其诱人的特性所倾倒。是时候认真看看Erlang究竟什么样了!

20084月,通过各种资料的搜集,了解,我决定系统的学习Erlang

今天,通过4个月的认真学习,我已经熟悉了Erlang,已经在使用Erlang开发项目。作为C++程序猿,我不敢妄自使用“熟悉”,“精通”之类的字眼,可是对于Erlang我能够非常负责任的说:Erlang非常巧,非常强大!

二、困惑

面对一个新的事务,我们本性都会充满好奇,但是作为程序猿,非常多时候对于新的语言我们都充满了抵触:这个新东西值得学习么?它会不会让我抛弃旧爱?它文档丰富么?是不是非常难理解?它的前景怎样?······相信大家跟我有一样的苦恼。

可是,请听我说!我们是程序猿,我们走在技术革新的最前沿。用户的产品,体验是通过我们来产生!我们不能畏缩不前,我们的固步自封,就是我们的公司,乃至整个行业的停滞不前!口号可能有些响亮,可是认真思考,我相信朋友们一定有所感悟。

三、Erlang是什么

Erlang是什么是我们最先要面对的问题,仅仅有清楚了它是什么,我们才干做出我们的决定。可见这个问题的重要性,它决定了非常多读者是否会继续看下去!非常紧张。

Erlang最初是爱立信为开发电信相关产品而产生。

Erlang是一种面向并发(Concurrency Oriented),面向消息(Message Oriented)的函数式(Functional)编程语言。

面向并发说明Erlang支持大规模的并发应用,我们能够在应用中处理成千上万的并发,而不相互影响。面向消息,事实上是为并发服务!我们应该都熟悉多线程,熟悉加锁解锁操作,熟悉可能出现的资源竞争与死锁。在Erlang的世界里,我们能够将轻轻的抹去这些令人苦恼的词汇。Erlang的世界,每一个处理都是独立的个体,他们之间的交互只靠消息!因此不会有死锁,不会有那种痛苦的编程经历。

Erlang中一个很重要的名词:Process,也就是我们前面提到的“个体”。它不是我们操作系统中的进程,也不是线程。它是Erlang提供给我们的超级轻量的进程。为了适应大规模并发的特性,Process须要能够高速创建,高速销毁。Process之间通信的唯一方法就是消息,我们仅仅要知道一个Process的名字即pid,就能够向其发送消息。Process也能够在不论什么时候,接收消息。我们这样做仅仅有一个目的:让我们的系统更加简单,用一种朴素的做法,实现一个高效的语言。

Erlang是种函数式编程语言,对此我没有非常深刻的理解,最明显的特征就是,Erlang中到处都是函数,函数构成了我们的产品的主体,把这些函数放到一个个的Process中去,让他们执行起来,那么就组成了我们朝气蓬勃的产品。

Erlang支持对数据的位操作,拥有丰富的数据持久化机制。

同一时候须要说明的是Erlang内建垃圾回收机制(GC)。

四、Erlang的语言特性

1.简单小巧

Erlang中仅仅有8种主要的数据类型:

integerfloatatomreferencefunportpidbitstring

同一时候提供2种复合结构:tuplelist,这就是Erlang的全部数据类型。

2.模式匹配

Erlang的函数中,某些语法中,我们能够使用Pattern匹配,这是一个很好的特性,我们能够让代码自己去决定怎样运行

比方,我们定义一个函数,其告诉我们某种水果的价格:

price(apple) -> 2.0;

price(banana) -> 1.2.

我们随后调用 price(Fruit),会依据Fruit变量的内容返回详细的价格。这样做的优点就是节省了我们的代码量,我们不用if…else…或者switch…case的来侍奉了。也便于代码的扩展:加一个新的水果品种,我们仅仅须要加一行就能够了。

学习Erlang一个很重要的内容就是模式匹配,可是请不要混淆,这个匹配和正則表達式没有不论什么干系。

3.变量单次赋值

这个是一个匪夷所思的特性,变量居然仅仅能单次赋值!是的Erlang中变量一旦绑定某个数值以后,就不能再次绑定,这样做的优点是便于调试出错(更深层次的原因是Erlang为并发设计,假设变量能够改动,那么就涉及到资源的加锁解锁等问题),当错误发生时,某个变量是什么就永远是什么,不用顺藤摸瓜的查找谁改动过它,省了好多事情。唯一的麻烦就是须要一个信的变量时,你必须再为它想一个名字。

4.丰富的libs

Erlang中提供丰富的libs

stdlib中包括大量的数据结构如listsarraydictgb_setsgb_treesetsdets

mnesia提供一个分布式的数据库系统

inets提供ftp clienthttp client/servertftp client/server

crypto 提供加密解密相关函数,基于openssl相关实现

ssl 实现加密socket通信,基于openssl实现

ssh 实现ssh协议

xmerl 实现XML相关解析

snmp 实现SNMP协议(Simple Network Management Protocol

observer 用来分析与追踪分布式应用

odbc 使Erlang能够连接基于SQL的数据库

orber 实现CORBA对象请求代理服务

os_mon 提供对操作系统的监控功能

dialyzer提供一个静态的代码或程序分析工具

edoc 根据源文件生成文档

gs 能够为我们提供某些GUI的功能(基于Tcl/Tk

还有非常多朋友提供了一些开源的lib,比方eunit,用来进行单元測试。

5.灵活多样的错误处理

Erlang最初为电信产品的开发,这种目的,决定了其对错误处理的严格要求。Erlang中提供一般语言所提供的exceptioncatchtry…catch等语法,同一时候Erlang支持LinkMonitor两种机制,我们能够将Process连接起来,让他们组成一个总体,某个Process出错,或推出时,其它Process都具有得知其推出的能力。而Monitor顾名思义,能够用来监控某个Process,推断其是否退出或出错。全部的这些Erlang都提供内在支持,我们高速的开发牢固的产品,不在是奢望。

6.代码热替换

你的产品想不间断的更新么?Erlang能够满足你这个需求,Erlang会在执行时自己主动将旧的模块进行替换。一切都静悄悄。

7.天生的分布式

Erlang天生适合分布式应用开发,其非常多的BIF(内建函数,相API)都具有分布式版本号,我们能够通过BIF在远程机器上创建Process,能够向远程机器上的某个Process发送消息。在分布式应用的开发中,我们能够像CC++,JAVA等语言一样,通过Socket进行通讯,也能够使用Erlang内嵌的基于Cookie的分布式架构,进行开发。当然也能够两者混合。分布式开发更加方便,高速。ErlangProcess的操作,Error的处理等都对支持分布式操作。

8.超强的并发性

因为採用其自身Process,而没有採用操作系统的进程和线程,我们能够创建大规模的并发处理,同一时候还简化了我们的编程复杂度。我们能够通过几十行代码实现一个并发的TCPserver,这在其它语言中都想都不敢想!

9.多核支持

Erlang让您的应用支持多个处理器,您不须要为不同的硬件系统做不同的开发。採用Erlang将最大限度的发挥你的机器性能。

10.跨平台

如同JAVA一样,Erlang支持跨平台(其眼下支持linuxmacwindows19种平台),不用为代码的移植而头疼。

我们只须要了解平台的一些特性,对执行时进行优化。

11.开源

开源是我很喜欢的一个词汇,开源意味这更加强壮,更加公开,更加的追求平等。开源会让Erlang更好。

五、Erlang与外界的交互

Erlang能够与其它的语言进行交互,如CC++,Java。当然也有热心的朋友提供了与其它语言的交互,假设须要你也能够依据Erlang的数据格式,提供一个库,让Erang与您心爱的语言交互。

Erlang支持分布式开发,您能够创建一个C Node,其如同一个Erlang节点,前提是你遵照Erlang的规范。

当然最经常使用的交互还是再同一个Node上,比方我们要调用某个lib,调用一些系统提供的功能,这时候主要有两种方式:Port和嵌入式运行。

PortErlang最主要的与外界交互的方式,进行交互的两方通过编码,解码,将信息以字节流的方式进行传递。(详细这个通道的实现方式,依据操作系统的不同而不同,比方unix环境下,採用PIPE实现,理论上不论什么支持相应Port通道实现的语言都能够与Erlang进行交互)。Erlang为了方便CJAVA程序猿,提供了Erl_InterfaceJinterface

採用Port,您的代码在Erlang的平台之外执行,其崩溃不会影响Erlang

嵌入式运行,通过Erlang平台载入,因此这是很危急的,假设您的程序崩溃,没有不论什么理由,Erlang也会崩溃。

六、Erlang应用场景

分布式产品,网络server,client,等各种应用环境。

Erlang也能够作为一种高速开发语言,进行原型开发。

七、Erlang的学习过程

1.         安装首先从Erlang官方站点,下载安装Erlanghttp://www.erlang.org/download.html

linux:获取源码,依据说明编译;windows:直接安装

2.         认真阅读《programming erlang》(中文版图书已经问世),并不断动手练习书中的例程。

3.         遇到问题时,不要退却,坚持下去找到解决的方法

4.         对语言熟悉时,浏览一些好的开源项目

5.         有信心时,開始动手做一个小项目

6.         不间断的与大家交流,共同提高

可能遇到的困难:

a)         对于语法的不适应?

坚持看下去,代码继续写下去,我相信1个月,你会喜欢上Erlang的语法

b)        有些数据类型不清楚?

认真看资料,或者询问朋友,比方我

c)         中文资料的缺乏?

Erlang中文的资料会越来越多,此外,Erlang的相关的英文资料也比較easy理解,还是那句话,别怕麻烦

八、Erlang开源项目

排名不分先后

  • couchdb     基于文档等非结构化数据的数据库,提供HTTP接口
  • disco       Map-Reduce框架,Erlang + Python
  • ejabberd    性能出众,使用广泛的Jabber开源server
  • mochiweb    轻便,高效的HTTP应用框架
  • rabbitmq    中间server,实现AMQP协议
  • yaws        高效的web server
  • etorrent    Bittorrentclient
  • scalaris      分布式的key-value存储

九、遇到问题

參看Erlang官方文档 http://www.erlang.org/doc/

订阅Erlangmaillisthttp://www.erlang.org/mailman/listinfo/erlang-questions),进行提问

Nabble提供的Erlang maillist存档中搜索(http://www.nabble.com/Erlang-f14095.html

Google中搜索答案

十、推荐阅读

Erlang Design Principles http://www.erlang.org/doc/design_principles/part_frame.html

Erlang Efficiency Guide http://www.erlang.org/doc/efficiency_guide/part_frame.html

Erlang Programming Rules http://www.erlang.se/doc/programming_rules.shtml

十一、推荐站点

http://www.erlang.org

http://erlang-china.org

http://trapexit.org (国内封锁,能够使用http://trapexit.org.nyud.net:8080/ 或其它代理登录)

http://toquick.com

http://blog.socklabs.com/

http://www.planeterlang.org/





版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/118815.html原文链接:https://javaforall.net

(0)
上一篇 2021年11月30日 下午9:00
下一篇 2021年11月30日 下午10:00


相关推荐

  • python 爱心代码_python浪漫代码

    python 爱心代码_python浪漫代码动态心型importturtleimporttimedefLittleHeart():foriinrange(200):turtle.right(1)turtle.forward(2)love=’Ilove草莓’turtle.setup(width=900,height=500)turtle.color(‘red’,’red’)turtle.pensize(3)turtle.speed(50)turtle.

    2022年10月13日
    6
  • 数学建模主成分分析法matlab_主成分分析法建模

    数学建模主成分分析法matlab_主成分分析法建模数学建模方法——主成分分析法Ⅰ.主成分分析:​ 主成分分析(PrincipalComponentAnalysis,PCA),将多个变量通过线性变换以选出较少个数重要变量的一种多元统计分析方法。主成分与原始变量之间的关系:​ (1)主成分保留了原始变量绝大多数信息。​ (2)主成分的个数大大少于原始变量的数目。​ (3)各个主成分之间互不相关。​ (4)每个主成分都是原始变量…

    2022年10月15日
    4
  • 【文心智能体】使用文心一言来给智能体设计一段稳定调用工作流的提示词

    【文心智能体】使用文心一言来给智能体设计一段稳定调用工作流的提示词

    2026年3月12日
    1
  • 演讲实录:OpenClaw数字员工/数字伴侣/AI资讯流实践

    演讲实录:OpenClaw数字员工/数字伴侣/AI资讯流实践

    2026年3月13日
    2
  • adb安装以及调试

    adb安装以及调试想必很多程序猿们都经历过一个头疼的事情是开发完一个项目之后,在你本机模拟是Ok的,但是到了正式环境上(机顶盒、手机等)却又bug百出,测试姐姐找的你头疼。那么我们就需要在自测的时候验证一下。废话不多说先来直接上正文:1.下载安装ADB下载安装非常快速简单,不到3MB。(需要下载的可以直接找我要)下载解压完之后不需要你去安装或者配置什么Path之类的东西,只需要记住你放在哪儿了就好。例如我放在了D盘,文件名叫ADB。2.是否正常运行输入:(1)win+R(2)进入cmd(3)D:(4)c

    2022年5月16日
    49
  • Redis集群搭建(非常详细)

    Redis集群搭建(非常详细)https blog csdn net article details redis 集群搭建在开始 redis 集群搭建之前 我们先简单回顾一下 redis 单机版的搭建过程 下载 redis 压缩包 然后解压压缩文件 进入到解压缩后的 redis 文件目录 此时可以看到 Makefile 文件 编译 redis 源文件 把编译好的 redis 源文件安装到 usr local redis 目录下 如果 local 目录下没有 redis 目录 会自动新建 r

    2025年10月28日
    6

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号