任何时候都不能人云亦云,别人说好的东西必须亲自尝试过之后才会有真切的体会。
对于erlang也是如此,因为自己之前一直是用java开发的,所以自觉不自觉得喜欢用java 和erlang来作比较,不比较还好,一比较之后真的会使自己陷入对erlang的怀疑。
测试1:
erlang执行速度和java比较:
测试内容是,创建1000万个有5个字符的随机字符串。
非常抱歉的高速各位,我测试的结果是erlang慢很多,我真希望是我代码写的有问题。
测试用的服务器是 16核24G内存的服务器,公平起见,都没有使用并发多进程,多线程。
Java代码如下:
public class TestDict { public static void main(String[] args) { final long current = System.currentTimeMillis(); for (int i = 0; i < 10000000; i++) { createRandomWord(); } System.out.println("consume:" + (System.currentTimeMillis() - current)); } private static String createRandomWord() { char[] chars = new char[5]; for (int i = 0; i < chars.length; i++) { chars[i] = (char) (97 + (int) (Math.random() * 26)); } return new String(chars); } }
编译:
javac TestDict.java
执行:
java TestDict
执行结果:
consume:1868
Erlang代码:
-module(test_dict). -compile(export_all). just_create_words(0)-> ok; just_create_words(N)-> create_random_word(), just_create_words(N-1). create_random_word()-> create_random_word([],0). create_random_word(Acl,5)-> Acl; create_random_word(Acl,N)-> create_random_word([97+ trunc(random:uniform()*26) |Acl],N+1).
编译:
erlc test_dict.erl
执行:
timer:tc(test_dict,just_create_words,[10000000]).
执行结果:
{29546820,ok} 29.5秒
结果对比:
看见了吧 java执行只需要1.8秒,而erlang需要29.5秒,如果说相差个1秒那还说得过去,为啥相差这么多?难道我写的代码有问题?
测试2:
测试二是在上测试1的基础上,将创建出的随机字符串put到map对象中他,map对象的value是一个Integer值,当map对象中如果已经有一个相同的key的话就将对应key的value值加一。
还是创将1000万个5个字符串的随机字符串,分别统计执行时间。
以下是java代码:
public class TestDict { public static void main(String[] args) { Map<String, AtomicInteger> wordCount = new HashMap<String, AtomicInteger>(); final long current = System.currentTimeMillis(); String key = null; AtomicInteger value = null; for (int i = 0; i < 10000000; i++) { key = createRandomWord(); value = wordCount.get(key); if (value == null) { wordCount.put(key, new AtomicInteger(1)); } else { wordCount.get(key).incrementAndGet(); } } System.out.println("consume:" + (System.currentTimeMillis() - current)); System.out.println("key size:" + wordCount.size()); } private static String createRandomWord() { char[] chars = new char[5]; for (int i = 0; i < chars.length; i++) { chars[i] = (char) (97 + (int) (Math.random() * 26)); } return new String(chars); } }
编译:
javac TestDict.java
执行:
java TestDict
执行结果:
consume:13698 key size:6759849
Erlang代码:
-module(test_dict). -compile(export_all). test_create_word(Dict,0)-> ok; test_create_word(Dict,N)-> dict:update_counter(create_random_word(),1,Dict), test_create_word(Dict,N-1). create_random_word()-> create_random_word([],0). create_random_word(Acl,5)-> Acl; create_random_word(Acl,N)-> create_random_word([97+ trunc(random:uniform()*26) |Acl],N+1).
编译:
erlc test_dict.erl
执行:
timer:tc(test_dict , test_create_word , [dict:new(),10000000]).
执行结果:
{38897271,ok} 38,8秒
结果对比:
对比两次执行操作时间,需要减去测试一的执行时间,多出来的时间就是操作K->V对象的时间:
Java版本执行时间:13.6-1.8=11.8秒
erlang版本执行时间:38.8-29.5=9.3秒
从测试结果来看,erlang的dict 对象执行速度还是比java的map对象快的,还快了两秒多。之前我有一个担心,那就是erlang的immutable object,我总是在想erlang是如何操作dict数据结构的呢,因为每次更新dict中的一个k-value值都会创建一个新的dict对象(这个操作对象的方式,在java中是完全不可以接受的),那么随着dict中key越来越多,操作dict数据结构的时间也会越来越长的,但是经过测试2的结果,让我完全打消对erlang dict性能的怀疑。
总结:
通过两个测试结果综合来看,erlang在计算随机数环节慢了,估计是random:uniform()执行比较慢的原因,另外欣慰的是在测试2中对k-v操作中erlang的dict胜出了,今后我可以在erlang的代码中放心地使用dict了。
相关推荐
**Erlang编程:Introducing Erlang** Erlang是一种函数式编程语言,由爱立信在1986年开发,主要用于构建高可用性、容错性和并发性的分布式系统。"Introducing Erlang"是Simon St. Laurent撰写的一本入门级教程,...
这本书不仅适合Erlang初学者阅读,而且对于那些对Erlang设计哲学和应用开发感兴趣的人也是极好的资源。通过学习本书,读者将能够掌握Erlang的基础知识,为编写可靠和高效的并发系统打下坚实的基础。
2. **API更新**:可能对Erlang的内置函数或模块进行增强,提供新的功能或修复已知问题。 3. **兼容性提升**:与先前版本相比,25.0可能增强了与其他软件或框架的兼容性。 4. **错误修复**:解决上一版本中的已知问题...
版本24.3.4.4是Erlang的一个更新版本,包含了对先前版本的改进和修复。Erlang以其强大的错误恢复能力和轻量级进程(称为Erlang进程)而闻名,这些进程具有内置的并发性和容错性。 在安装Erlang 24.3.4.4之前,首先...
Erlang22是Erlang的第22个主要版本,它包含了对语言特性的改进、性能优化以及一些新的库和工具。 在“erlang22最新下载包”中,提供的文件是`otp_src_22.1`,这表明这是一个源代码包,包含Erlang/OTP(开放电信平台...
Linux是Erlang广泛应用的平台之一,因为其开源特性和对并发处理的良好支持与Erlang的理念相契合。 在实际使用Erlang时,开发者会遇到诸如OTP(Open Telecom Platform)这样的核心组件,它提供了一套标准库和框架,...
对于学习C++编程和通信网络的人来说,阅读和分析这部分代码可以深化对Erlang B公式的理解,并提升编程技能。 实验报告则可能包含了项目背景、设计思路、实现过程、测试结果和性能评估等内容。这有助于读者了解实际...
Erlang/OTP 26.2.1,Erlang,OTP,26.2.1
这个“erlang资源”包含两本PDF书籍——《Erlang并发编程》和《Erlang入门手册》,它们是深入理解和学习Erlang语言的关键资料。 《Erlang并发编程》这本书可能涵盖了以下知识点: 1. **并发模型**:Erlang的并发...
Erlang是一种面向并发的、函数式编程语言,主要用于构建高度可扩展的、容错性强的分布式系统。在IT行业中,Erlang因其强大的实时性和处理大量并发连接的能力而被广泛应用于电信、互联网基础设施和实时系统。RabbitMQ...
Erlang B和Erlang C是电信领域中两种重要的流量模型,用于预测和分析通信系统中的呼叫处理能力和拥塞情况。这两个模型由丹麦工程师Agner Krarup Erlang在20世纪初提出,至今仍广泛应用于现代通信网络的设计与优化。 ...
这通常需要对Erlang的VM(Virtual Machine)和调度器有深入理解。 8. **Erlang与其他技术的集成**:Erlang可以与其他语言如Java、Python等集成,用于构建混合系统。例如,使用Erlang的Ranch和Cowboy库可以构建高...
Erlang是一种面向并发的、函数式编程语言,主要用于构建高度可扩展的、容错性强的分布式系统。在IT行业中,Erlang因其强大的实时性、并发性和内存管理机制而被广泛应用于网络通信、数据库系统以及消息中间件,如...
【Erlang编程语言及其应用】 Erlang是一种并发式、函数式的编程语言,由瑞典电信设备制造商Ericsson开发,最初用于构建高可用性、容错性和可扩展性的分布式系统。"xiandiao_erlang_Erlang课后习题_"这个压缩包文件...
erlang安装包
Erlang是一种高级编程语言,特别适用于并发、分布式和实时计算系统。它的设计目标是创建一个高可用性、容错性强、低延迟的系统。Erlang9指的是Erlang/OTP(Open Telephony Platform)的第9个主要版本。OTP是Erlang...
这个版本可能包含了对Windows平台的优化,以确保在该系统上高效运行。 描述中的"erlang23.2版windows64位"进一步确认了这个软件包是Erlang 23.2,适用于64位的Windows操作系统。这意味着它能够充分利用64位系统的...
**软实时性**:Erlang采用递增式垃圾收集,确保系统能及时响应,但不保证严格的时间限制,适合于那些对响应时间有一定要求但又不是硬实时要求的系统。 **热代码升级**:Erlang允许在运行时升级代码,新旧版本的代码...
erlang otp25 win安装包
Erlang的独特之处在于其对并发的处理方式,它使用轻量级进程(Lightweight Processes,LWP)实现微内核架构,这使得在单个节点上可以同时运行数千个进程。OTP的引入进一步强化了这种并发能力,提供了诸如GenServer、...