Erlang-编译、运行和命令行参数(转自-“Quick & Win -- 五多”)

来源:互联网 发布:怎样参加淘宝聚划算 编辑:程序博客网 时间:2024/06/05 17:02

 

1. erlang:halt()可以即刻停止系统运行。

2. q()命令可以完成文件和数据库的一些处理后再退出。它是init:stop()的一个shell别名

3. erlang可以动态加载代码,正在运行的代码可以在重新编译后动态加裁而不用停止程序的运行。

4. 模块加载相关函数:

  code:get_path() %%可以获取当前加载路径的设定值。

  code:all_loaded() %%获取所有已经加载的模块。

  code:clash() %%看加载的模块是否有冲突。

另外

  @spec code:add_patha(Dir) => true | {error, bad_directory} %%增加一个新的目录到加载路径的开头。

  @spec code:add_pathz(Dir) => true | {error, bad_directory} %%增加一个新的目录到加载路径的末尾。

5. 启动erlang时增加加载路径:

  erl -pa Dir1 -pa Dir2 ... -pz DirK1 -pz DirK2

  其中-pa相当于add_patha,-pz相当于add_pathz

6. 在erlang的home目录下(或当前目录下)可以加一个.erlang文件,在这个文件中可以写一些erlang代码,erlang在启动时首先执行这里面的代码。

   一般情况一下可以将加载目录的命令放到这个。

   如果不清楚当前系统下erlang的home目录,可以用init:get_argument(home).来获取。

   当前目录下的.erlang文件比home目录下的.erlang文件的优先级要高。

 

7. 除了在shell中运行一个模块外,还有以下的方法:

   方法一:命令行下编译运行

   $ erlc hello.erl

   $ erl -noshell -s hello start -s init stop

   %% 可以加-pa/-pz命令选项在这个命令行中

   %% 可以将这个命令行写到一个shell脚本中(如bash脚本),这样就可以直接执行脚本平启动erlang程序了。

   %% 在windows下可以写一个bat文件,将这个命令写入。

   方法二:将程序当作escript脚本运行(不用编译),只有erlang R11B-4以后的版本才支持escript,在windows下不行

   #!/usr/bin/env escript

main(_) -> io:format("Hello world\n"). %%这个函数需要是main,escript从这个函数开始

   方法三:当程序需要参数时,如何在命令行输入参数。

   -s选项后面是:ModName FuncName Args,其中Args是一个原子的参数列表。所以我们在程序中最好有一个处理命令行参数的函数。像这样: main([A]) -> I = list_to_integer(atom_to_list(A)), ... %% 这里只接收一个参数,如果需要两个可以这样main([A, B]) -> ...

escript与其它的脚本一样,运行时直接将参数放到后面就可以了。

8. atom_to_list(Atom) -> string可以获取原子的字符串形式

9. list_to_integer(List) -> int可以获取一个字符串的整数形式

10. 快速脚本:用-eval在命令行上直接运行一个erlang表达式,这个方法没什么大用途,我在windows测试好像没有显示什么内容。

erl -eval 'io:format("Memory: ~p~n", [erlang:memory(total)]).' -noshell -s init stop

 

11. 一个makefile模板

# leave these lines alone

.SUFFIXES: .erl .beam .yrl # .yrl文件是erlang解析生成器程序(yecc)的解析定义文件

 

.erl.beam:

erlc -W $<

 

.yrl.erl:

erlc -W $<

 

ERL = erl -boot start_clean

 

# edit the lines below

MODS = module1 module2 \

module3 ... special1 ...\

muduleN

 

all: compile

 

compile: ${MODS:%=%.beam} subdirs

 

#特殊情况,特殊编译

special1.beam: special1.erl

${ERL} -Dflag1 -W0 special1.erl

 

#运行程序

application1: compile

${ERL} -pa Dir1 -s application1 start Arg1 Arg2

 

#编译子目录,子目录中也有makefile

subdirs:

cd dir1; make

cd dir2; make

 

clean:

rm -rf *.beam erl_crash.dump #erl_crash.dump是erlang的崩溃转存文件

cd dir1; make clean

cd dir2; make clean

 

12. 一个精简makefile

.SUFFIXES: .erl .beam

 

.erl.beam:

erlc -W $<

 

ERL = erl -boot start_clean

 

MODS = module1 module2 module3

 

#编译加运行

all: compile

${ERL} -pa Dir1 -s module start

 

compile: ${MODS:%=%.beam}

 

clean:

rm -rf *.beam erl_crash.dump

 

13. erlang shell中有一个emacs编辑器中的行编辑命令的一个子集。对于不用emacs的人没有什么用,比如我。

 

14. erlang启动时带有一个-detached选项,它后在后台运行

15. erlang启动时带有一个-heart Cmd选项,系统会启动一个监视进程,如果发现erlang进程死亡,监视进程就会执行Cmd,通常Cmd会重启Erlang系统。

 

16. 如果调用一个eralng函数时发生undef错误,可能是以下几种原因:

(1)系统中不存在这个模块或函数,可能是拼写错误。

(2)系统中有这个模块,但没有编译。

(3)已经编译了,但它所在的目录不在erlang的加载路径中。

(4)加载了几个不同版本,我们可以通过code:clash()函数来看一下是否有重名的模块。

 

17. JCL(Job Control Language)模式:在erlang shell中按下Ctrl+G会进入JCL模式,可以输入h寻求帮助。

 

18. man:在Unix系统的命令行中执行:$ erl -man lists可以看到lists

 

19. 世界是并行的。

20. erlang程序模拟我们思考的反应的模式。

21. 人就像是一个通过发送消息来进行交流的实体。

22. 如果有人死了,其他人会注意到。

 

原创粉丝点击