<html>
<head>
<style><!--
.hmmessage P
{
margin:0px;
padding:0px
}
body.hmmessage
{
font-size: 10pt;
font-family:Tahoma
}
--></style></head>
<body class='hmmessage'><div dir='ltr'>
Yes, I could write an essay on this one..<div><br>The other thing to remember about all these Java (and C++) libraries is that there are, frankly, so many of them. Each time you look at one it's a whole different set of semantics that need learning. With Erlang you have a single set of concurrency principles that need learning that are core to the language, and who's behavior is well understood. It makes for code that is easy to reason about, especially when things go wrong. I also worry that many of these Java libraries are only going to be supported until something shinier, newer or better comes along. I should add here that I have recently started learning Java, and quite like the language, especially compared to the effects that C++ has had on my hairline. ;-)</div><div><br></div><div>Having said that there is a valid criticism of Erlang in that it is often perceived to be too slow. As Joe said, you can't have all the features of resilience and reliability without some cost, but when trying to "sell" Erlang it's often the first argument against Erlang that I hear. The pointy haired managers look at things like the Alioth shootout and see Erlang perform poorly for most tests. Now, most Erlang users will correctly say "well, Erlang isn't designed for those types of highly serial tasks, use C, C++ or Java for that instead, and use Erlang where it makes sense". But this now means that a company needs to embrace 2 (perhaps more) languages to do a job. This isn't necessarily a bad thing, but can make for pain when hiring, training and retaining staff.<br><br>My point is that I don't think Erlang will ever be as fast as Java and certainly never as fast as C/C++, but I would like to see a greater focus on performance, perhaps get it into the top 10 languages for performance. I'm happy to see that work is been done WRT to JIT in the Erlang VM, and LLVM+HiPE, so maybe future releases will address those concerns.</div><div><br></div><div>I've also often wondered if it makes sense to implement some of the Kernel and STDLIB modules as BIFs instead of in Erlang. Would that improve things?</div><div><br></div><div>Matt</div><div>________________________________<br>> Date: Sat, 11 Feb 2012 13:20:54 +0100 <br>> From: poprosturadek@gmail.com <br>> To: ulf@feuerlabs.com <br>> CC: erlang-questions@erlang.org <br>> Subject: Re: [erlang-questions] The future of Erlang and BEAM <br>>  <br>> # the same as above, sorry for inconvenience <br>>  <br>> Hi Ulf, <br>>  <br>> thank you very much for answer. <br>>  <br>> I understand that Erlang has been created in purpose of managing  <br>> coordination complexity and it does it's job well. <br>> But, maybe I'm a bit of devil's advocate, let's say that we (by which I  <br>> mean mostly OTP team because of their knowledge of Erlang intrinsics  <br>> but others too) could follow similar direction that Clojure's creator  <br>> Rick Hickey took. Which means, to build Erlang on JVM, using tools that  <br>> we already have (like earlier mentioned Java libraries, etc) and  <br>> optimize it for using with JIT. <br>>  <br>> Of course, it's not obvious that (despite being big effort) it would  <br>> bring desired performance (although, it seems it would) but some  <br>> advantages for sure, like ubiquity of JVM, wide gremium of  <br>> supporters/maintainers, ease of deployment (even single .jar maybe),  <br>> access to huge variety of other languages and libraries, and even some  <br>> minor things like proper module managament, etc. <br>>  <br>> As I said before, I'm rather novice in Erlang world (still digging  <br>> through Erlang and OTP in Action) so all above may be  <br>> wrong/incomplete/etc. I had this idea some time ago so I finally took  <br>> decision to write about my concerns here. <br>>  <br>> Greetings, <br>> Radek <br>>  <br>> _______________________________________________ erlang-questions  <br>> mailing list erlang-questions@erlang.org  <br>> http://erlang.org/mailman/listinfo/erlang-questions <br></div>                                        </div></body>
</html>