记录与映射组
记录 (record)
记录其实是元组的另一种形式。通过使用记录,可以给元组里的各个元素关联一个名称。
记录使用方法
通过记录命名元组里的元素:
-record(Name,{
Key1 = Default1,
Key2 = Default2,
…
key3,
})
创建记录
#Name{Key1=Val1,Key2=Val2…}. % 所有的键都是原子
提起记录字段
用模式匹配操作符
映射组:
映射组是键值对的关联性集合。键可以是任意的 Erlang 数据类型。(c++/java 里的 map,哈希表)。
#{Key1 Op Val1,Key2 Op Val2,…}
Op 可以是 => 或者:=
=> 可以更新现有键的值,如果现有键不存在则创建新的键。:= 只能用来更新现有键的值,如果键不存在则报错。
record 或者有几个参数写几个,我们习惯这样 map 不是不行,只不过 1)受到版本限制;2)需要用注解的形式告诉使用者可以填哪些参数;3)万一定义和使用时写的不同名字,不能通过编译器来发现问题因为是非静态类型语言,本来编译期内发现问题的机会已经减少很多了,还到处是 map,就更难通过编译器发现问题了~map 有个好处,record 没有的,是如果用 map 代替 record,那么就不存在 record 改了线上不能热更的问题~:Dmap 我认为应该用在不确定参数的场合;而如果是参数确定的,但是可填可不填,其实用 map, record, 参数列表,没什么区别,都是要去判断~
顺序程序的错误处理
异常错误是系统内部发生错误,或者通过在代码里显式调用 exit(Exception)、throw(Exception) 或 error(Exception) 时发出的信息。典型内部错误有
模式匹配错误
用错误类型的参数调用函数
用带有错误类型的参数调用内置函数
抛异常的三种函数
exit(Why). 一般用于终止当前进程
error(Why). 指示“崩溃性错误”,也就是调用者没有准备好处理的非常严重的问题,与内部错误差不多。
throw(Why). 抛出一个调用者有可能想要捕捉的异常错误。
捕捉异常的方式
1、把抛出异常的调用函数封装在 try…catch 表达式里
try FunOrExperssionSeq of
Pattern1[when guard1] -> Experssions1;
Pattern2[when guard2] -> Experssions2;
…
catch
ExceptionType1:Expattern1 [when ExGuard1] -> ExExpressions1;
ExceptionType2:Expattern2 [when ExGuard2] ->ExExpressions2;
…
after
AfterExperssions
end
2、把调用封装在 catch 表达式里
catch FunOrExperssionSeq
二进制与位语法
类型
spec : 类型规范
type:类型声明