周五没事瞎吹,讨论==和=:=区别,看他们讨论的热火朝天,我二话不说直接开撸测试一下。
备注:时隔几个月回来浏览帖子,发现这篇代码的时间计算有问题,导致出现212000和9215000这样的差距,原因是os:timestamp的Micr微妙位数不是固定的,有时是6位,有时是3位,otp21版本貌似修复了。以下代码等我有空了回来修改
-module(t).
-export([test/0,timestamp/0]).
test()->
[ guess(fun a/1 ),guess(fun b/1 ) ].
guess(F)->
Start = timestamp(),
F(50000000),
timestamp() - Start.
a(0) -> 0;
a(N) when 1 == 1 -> a(N-1).
b(0) -> 0;
b(N) when 1 =:= 1 -> b(N-1).
timestamp() ->
{M, S, Micr} = os:timestamp(),
1000000000000 * M + S * 10000000 + Micr.
看结果得知大多数情况下用=:=要快。
后续