1.Erlang的设计哲学是为每一个独立的事件创建一个新进程.
2.Erlang的容错处理:如果不能完成一个任务就死掉 让其它正常的进程来善后。link函数就是用来建立这种进程间的双向连接来监测非正常退出,并做出处理。
3.BIFs是built-in functions的缩写代表这些方法是Erlang运行时系统的一部分
4.side-effect-free无副作用,其中一种定义是说:一个程序执行前后保持程序的状态不变,不改变非局部变量的值,不改变传入参数值,也无I/O
5.写测试模块的时候不必频繁导出函数 –compile(export_all) 就可以导出所有函数
6.Erlang中整数值没有上限值,最大值只是受限于硬件(内存有多大)
7.在Erlang Shell中可以方便的做进制转换:Base#Value Base的范围2~16 2#101011
8.Erlang Shell中查询ASCII码 $1 $a $A $\n $\}
9.Erlang Shell中释放变量使用f() 定义record使用rd(),读取shell输入使用io:read/1可以接受输入Erlang term.
10.Erlang Shell中接受消息使用flush() 自己的Pid是self() 查看进程信息使用processes() i() 但是不要在进程非常多的场景使用,会消耗大量内存
11.atom是否已经注册的:registered() unregister(Pid) whereis(Atom) regs().
12.atom能够进行的唯一运算就是比较
13.atom是可以使用.和@的,但是别给自己添乱
14.atom会被记录在ERT系统表中,只需要几个字节,atom之间比较起来也很快
15.atom不参与Erlang GC,所以atom不能无节制的创建,list_to_existing_atom可以一定程度上缓解创建重复atom的内存消耗
16.Tuple是Erlang表达复杂数据结构的手段,第一个元素经常被称作Tag,Tag Massage是Erlang编程的最佳实践
17.Tuple索引是从1开始的,执行一下 element(1,{a,b,c}).看看 再试一下element(0,{a,b,c})看看报什么错
18.Tuple大小使用tuple_size({1,2,3,4,5}).
19.M++N会遍历列表M所以如果必须要使用++也要让数据量小的List在前面
20.proplist对于处理key_value的list真的是非常方面
21.List=[Element|List]所以你可以在shell中可以输入[1,2|3],尝试匹配一下它 [A,B,C]=[1,2|3]再试一下[P,Q]=[1,2,3]
22.List最后一个元素是空列表[],被称作well-formed list正则列表,[1,2|3]这种结构要避免
23.--操作符是针对元素进行的 [1,2]--[3]结果是[1,2] [2,2]--[2]结果是[2],运算顺序是从右到左, [1,2,3]--[1,2]--[1].结果是[1,3]
24.number<atom<reference<fun<port<pid<tuple<list<binary 之所以有这样一个比较关系,就是为了支持泛型比较
25.=:= =/=精确比较运算不仅比较值,还比较类型,效率更高
26.Erlang GC的特点是:每个进程独立进行GC ,分代(generational garbage) ,复制回收
27.Erlang的模式匹配作用:1.变量赋值 2.提取变量值 3.控制流
28.写function的时候在最后添加一个catch_all的方法也被认为是最佳实践
29.如果可预见结果集的所有可能性,那么case语句不建议使用catch_all
30.if语句会对Guard子句做catch,所以 if 1/0 ->a; true ->b end.的返回值是b而不是抛出异常
31.if的Guard子句放在变量里就可以让异常抛出来:G=1/0 , if G->a; true ->b end.
32.Guard subexpressions resulting in a runtime error are treated as returning false.
33.Guard可以使用, ; 表达多个条件if X=:=1,Y<2;X+Y<4 ->ok; true ->error end.
34.process dictionary几乎被描述成洪水猛兽了,对于一次写入然后就只读的配置性数据放在进程字典应该没有问题
35.Erlang出错法则:让错误报告在它发生的地方
36.查看module的元数据信息 比如a.erl a:module_info(). m(a).
37.Erlang的元编程Meta Programming确实直接,apply/3 甚至在参数确定情况下的直接调用M:F(A)
38.Concurrency is the ability for different functions to execute in parallel without affecting each other unless explicitly programmed to do so.
39.我们要遍历ETS可以使用first/next 也可以使用foldr foldl,但是后者会把ETS数据复制到进程,数据量大时有效率问题
40.负责进程创建职责的是Erlang VM中的Scheduler
41.spawn第三个参数是List,这个调用的时候注意!!
42.Spawning a process will never fail!!!
43.Sending a message will never fail!!!
44.receive子句的处理逻辑抽取为一个独立的方法是推荐的做法
45.receive如果接受到没有匹配任何子句的消息,那么这条消息就会保存在mailbox,长此以往就会耗尽内存系统崩溃之险;
46.消息发送的速度快于进程处理的速度就会增加CPU上的消耗,因为会反复扫描mailbox
47.Not handling unknown messages should therefore be treated as a bug. 匹配未知消息会导致难以发现错误,所以这些位置要记录日志
48.选择性接受和mailbox这两个东西就解决了消息接受缓冲区的问题
49.A race condition occurs when the behavior of a system depends on the order in which certain events occur: these events “race” to influence the behavior.
50.上面两个不失败的设计原则是为了解除进程依赖:另外一个进程的创建和接受消息是否成功不影响当前进程的正常执行
51.timer:tc/3计算方法的执行时间 这个构建简单的性能测试很方便
52. {'EXIT', Pid, Reason}退出消息的格式包含的信息:谁因为什么退出了
53. process_flag(trap_exit, true).退出截获的决策当然是在生命周期的早期进行配置。所以一般出现在init阶段。
54.截获到底做了一件什么事情呢?把退出消息放在进程收件箱中当成一个普通的消息来处理。这就相当于我们把异常信息放在返回结果中的情况
55.receive接收并处理退出信号,退出消息被截获就不再传播
56.link是双向的,monitor是单向的,被监控的进程死掉后,监控进程会收到 {'DOWN',Reference,process,Pid,Reason} 消息
57.如果接收到{'EXIT', Pid, Reason}的进程没有trap_exit,而且Reason不是normal,这个进程就会终止掉并继续传播这个退出消息
58.所有的BIFs的执行都是原子性的,所以spawn_link不等同于spawn 和 link的组合调用
59.{'EXIT', Pid, Reason}Reason如果是kill,关联进程无论是否trap_exit都会死掉
60.{'EXIT', Pid, Reason}Reason如果是normal,关联进程trap_exit会收到一条{'EXIT', Pid, normal}消息,如果没有trap_exit什么都不会发生
61. 可以使用record_info()来查看record定义
62.ETS也是不参与GC的
63.Erlang是动态强类型的语言 dynamic-strong Typing
64.windows环境Erlang GUI工具:toolbar:start(). tv:start() pman:start(). appmon:start() debugger:start()
65.还有一个WebUI的工具 webtool:start().
66.Note: Using the form [1 | 2] gives what we call an 'improper list'. Improper lists will work when you pattern match in the [Head|Tail] manner, but will fail to be used with standard functions of Erlang (even length()). This is because Erlang expects proper lists. Proper lists end with an empty list as their last cell. When declaring an item like[2], the list is automatically formed in a proper manner. As such, [1|[2]] would work! Improper lists, although syntactically valid, are of very limited use outside of user-defined data structures.
67.在EShell中执行Erlang方法
$> erl -boot start_clean -noshell -eval 'io:format("hi\n")' -eval 'halt(0)'
% or
$> erl -boot start_clean -noshell -eval 'io:format("hi\n"), halt(0)'
% example:
erl -sname ad_service -eval 'ok=mnesia:create_schema([node()]).' -s init stop
68.打印浮点型
lists:flatten(io_lib:format("~.*..f", [2, S]));
3> lists:flatten(io_lib:format("~.*..f", [2, 192.2225])).
"192.22"
4> lists:flatten(io_lib:format("~.*..f", [3, 192.2225])).
"192.223"
5> lists:flatten([io_lib:format("~8.2.0B,", [L]) || L <- [1,2,3]]).
"00000001,00000010,00000011,"
6> lists:flatten([io_lib:format("~2.16.0B ", [L]) || L <- [1,2,3]]).
"01 02 03 ".
69.找出消耗内存最多的进程
lists:reverse(lists:keysort(2,[{P, erlang:process_info(P, heap_size)} || P <- erlang:processes()])).
70.找到最消耗内存的ETS表
lists:reverse(lists:keysort(2,[{T, ets:info(T, memory)} || T <- ets:all()])).
71.record类型作为参数的小技巧
-record(x,{name,zz}).
-record(y,{yy,name}).
-export([test1/0,test2/0]).
-define(create(Type,Name),#Type{name = Name}).
test1() -> ?create(x,"Noel"). % -> {x,"Noel",undefined}
test2() -> ?create(y,"Noel"). % -> {y,undefined,"Noel"}
72.binary_to_list VS bitstring_to_list
1> A = <<1:2, 23:6>>.
<<"W">>
2> B = <<1:2, 23:5>>.
<<55:7>>
3> binary_to_list(A).
"W"
4> binary_to_list(B).
** exception error: bad argument
in function binary_to_list/1
called as binary_to_list(<<55:7>>)
5> bitstring_to_list(A).
"W"
6> bitstring_to_list(B).
[<<55:7>>]
73.Erlang执行操作系统命令 os:cmd("uptime").
74.[3] or "3"
17> [51] =:= "3".
true
18> [3] =:= "3".
false
19>
75.
如果仅仅是将一系列的模块打包在一起,并不需要启动application,那么只需要在app文件中移除掉{mod,{Module,Args}}配置节即可.这种Libiary Application典型范例就是stdlib.
相关推荐
**Erlang编程:Introducing Erlang** Erlang是一种函数式编程语言,由爱立信在1986年开发,主要用于构建高可用性、容错性和并发性的分布式系统。"Introducing Erlang"是Simon St. Laurent撰写的一本入门级教程,...
Erlang是一种面向并发的、函数式编程语言,由瑞典电信设备制造商Ericsson开发,主要用于构建高可用性、分布式和实时系统。版本24.3.4.4是Erlang的一个更新版本,包含了对先前版本的改进和修复。Erlang以其强大的错误...
Erlang是一种高级编程语言,特别适用于并发、分布式和实时系统。它由Ericsson公司开发,主要用于构建高可用性、容错性和可扩展性的软实时系统。Erlang的25.0版本是该语言的一个更新,针对Windows操作系统进行了优化...
Erlang是一门专为构建并发、容错的分布式系统而设计的编程语言,最早由瑞典电信设备公司爱立信所开发。其关键特性包括轻量级进程、消息传递、容错机制以及一个用于构建可靠系统的函数库和中间件,统称为Open Telecom...
Erlang是一种面向并发的、函数式编程语言,由瑞典电信设备制造商Ericsson为了实现分布式实时、高可靠性系统而开发。Erlang以其强大的并行处理能力、容错性和易于构建大规模分布式系统的特点,在电信、金融和互联网等...
这个“erlang资源”包含两本PDF书籍——《Erlang并发编程》和《Erlang入门手册》,它们是深入理解和学习Erlang语言的关键资料。 《Erlang并发编程》这本书可能涵盖了以下知识点: 1. **并发模型**:Erlang的并发...
Erlang B和Erlang C是电信领域中两种重要的流量模型,用于预测和分析通信系统中的呼叫处理能力和拥塞情况。这两个模型由丹麦工程师Agner Krarup Erlang在20世纪初提出,至今仍广泛应用于现代通信网络的设计与优化。 ...
Erlang/OTP 26.2.1,Erlang,OTP,26.2.1
Erlang是一种面向并发的、函数式编程语言,主要用于构建高度可扩展的、容错性强的分布式系统。在IT行业中,Erlang因其强大的实时性和处理大量并发连接的能力而被广泛应用于电信、互联网基础设施和实时系统。RabbitMQ...
Erlang是一种面向并发的、函数式编程语言,由瑞典电信设备制造商Ericsson于1986年开发,主要用于构建高可用性、分布式系统。Erlang的设计目标是支持大量并发连接,容错性强,易于编写实时系统。Erlang采用actor模型...
Erlang是一种面向并发的、函数式编程语言,主要用于构建高度可扩展的、容错性强的分布式系统。在IT行业中,Erlang因其强大的实时性、并发性和内存管理机制而被广泛应用于网络通信、数据库系统以及消息中间件,如...
【Erlang编程语言及其应用】 Erlang是一种并发式、函数式的编程语言,由瑞典电信设备制造商Ericsson开发,最初用于构建高可用性、容错性和可扩展性的分布式系统。"xiandiao_erlang_Erlang课后习题_"这个压缩包文件...
Erlang是一种面向并发的、函数式编程语言,由瑞典电信设备制造商Ericsson开发,用于构建高可用性、分布式和实时系统。Erlang因其在处理大量并发连接和容错能力上的优秀表现,广泛应用于电信、银行、互联网服务等领域...
Erlang B公式是通信网络领域中用于计算呼叫阻塞概率的重要工具,它在电路交换系统,特别是电话交换网络的设计中发挥着关键作用。这个压缩包包含了一个基于Erlang B公式的计算器程序,以及其源代码和实验报告,旨在...
Erlang是一种高级编程语言,特别适用于并发、分布式和实时计算系统。它的设计目标是创建一个高可用性、容错性强、低延迟的系统。Erlang9指的是Erlang/OTP(Open Telephony Platform)的第9个主要版本。OTP是Erlang...
Erlang是一种强大的编程语言,特别适合于构建高并发、分布式和容错性强的系统。由爱立信的CS-Lab开发,Erlang的设计目标是处理大规模并发活动,这在传统的操作系统上可能非常困难。它的核心特性使其在处理并发性、...
erlang otp25 win安装包
erlang安装包
Erlang是一种面向并发的、函数式编程语言,主要用于构建高度可扩展的、容错性强的分布式系统。在“erlang programming”这个主题下,我们可以深入探讨以下几个关键知识点: 1. **Erlang语言基础**:Erlang是瑞典...
RabbitMQ version Minimum required Erlang/OTP Maximum supported Erlang/OTP Notes 3.13.0 26.0 26.2.x The 3.13 release series is compatible wtih Erlang 26. OpenSSL 3 support in Erlang is considered to ...