模块是erlang的基本代码单元,erl文件编译后以.beam作为扩展名,采用utf8字符集,.erl文件示意如下:
-module(模块名,与存放模块的文件名相同)
-export([方法名/输入参数的个数])
method1( {a,b,c})->a*b*c;
mehtod2({d,e})->d-e.
模块属性有两种类型:预定义型和用户定义型。
erlang中用于代表函数的数据类型被称为fun,相当于python中的lambda,一般用于
1) 对列表里的每个元素执行相同的操作
2) 创建自己的控制
3) 实现可重入解析代码,解析组合器或者lazy evaluator
模式匹配是erlang的根基,case和if表达式使erlang小而一致。
case expression of
pattern1[ when guard1] -> expr-seq1;
pattern2[when guard2]-> expr-seq2;
…
end
if
guard1-> expr_seq1;
guard2-> expr_seq2;
…
end
erlang有两种方法来捕捉异常错误,一种是把抛出异常的调用函数封装在一个try_catch 表达式里,提供了概括信息,另一种是把调用封装在一个catch表达式里,提供了详细的栈跟踪信息。在捕捉到一个异常后,可以调erlang:get_stacktrace()来找到最近的栈信息。
把二进制型,位串,和位级模式匹配引入erlang是为了简化网络编程。二进制型是置于双小于号和双大于号之间的一列整数或字符串。
例如: 1> mybin1 = << “ilove you”>>
term_to_bingary(term) ->bin 转换为二进制型
binary_to_term(bin) ->term 二进制型转换为erlang的数据类型
精心选择宏的名称和erlang代码布局,能最大限度地缩小c和erlang的语义鸿沟。在erlang里,最小的寻址单元是1位,位串里的位序列可直接访问。