记录与映射组
记录(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 :类型声明
发表回复