1.两二进制数据的合并:
A = <<1, 2, 3>>.
B = <<4, 5, 6>>.
% A + B 这个方法是不可行的
% 1.简单方法
C = <<A/binary, B/binary>>.
2.如果可以,不适用erlang:now()作为随机函数的种子,原因:如果每个进程调用random:seed(erlang:now())太接近,种子值会比较接近,生成的随机数也会比较接近,更好的方法是用一个单独的进程来生成种子,保证每次的种子值相差比较大
3.形如:[{X,Y,Z} || X<-lists:seq($0,$2),Y<-lists:seq($a,$d),Z<-lists:seq($A,$B)]. 可以看作从左往右得三层for循环(左为上层)
4.如何在Erlang Shell里面怎么写尾递归, 要把尾递归要执行的当前方法作为参数传进去,如
Func = fun(F, X,Y) when Y<10000 ->io:format("~p,",[X+Y]), F(F,Y,X+Y); (F,X,Y)-> done end.
%% Func(Func,0,1).
%% 1,2,3,5,8,13,21,34,55,89,144,233,377,610,987,1597,2584,4181,6765,10946,done
5.如果不想当前的erl_shell崩溃导致某些信息丢失,可以在shell上面执行 catch_exception(true).