> They did cite a significant performance boost as a side effect. I think it isn't very clear from the wording. They didn't just rewrite it in Java, they also changed the architecture:
> Storm 2.0.0 introduces a new core featuring a leaner threading model, a > blazing fast messaging subsystem and a lightweight back pressure model So it is hard I think to do an apples to apples comparison. In my opinion, a system like Storm will fundamentally be more limited by its architecture in performance than the language it uses. That said, even if I think the performance improvements are probably mostly due to architectural changes they also made. It shouldn't come as a surprise that Java would be faster than Clojure in most cases. I don't want to make false pretenses. Clojure and Java are not equal in semantics, and Java's mutable, eager and object grouped methods semantics are almost always going to be more performant. Clojure makes a trade offs of performance and memory for simplicity. When people say Clojure can match Java in performance, it almost always implies using escape hatches and changing the semantics back to imperative code. The good news though, when you use Clojure's semantics, you benefit in simplicity and the performance impact is marginal, so it is still fast enough for almost all use cases. Now, back to type annotations. I really don't think Storm 2.0 performance improvements were due to usage of reflection that hadn't been addressed from Clojure. But who knows. Do the framework you're talking about do static analysis of the types? Because generic types are erased at runtime, so there wouldn't ever be a way for proxy to set them in. -- You received this message because you are subscribed to the Google Groups "Clojure" group. To post to this group, send email to clojure@googlegroups.com Note that posts from new members are moderated - please be patient with your first post. To unsubscribe from this group, send email to clojure+unsubscr...@googlegroups.com For more options, visit this group at http://groups.google.com/group/clojure?hl=en --- You received this message because you are subscribed to the Google Groups "Clojure" group. To unsubscribe from this group and stop receiving emails from it, send an email to clojure+unsubscr...@googlegroups.com. To view this discussion on the web visit https://groups.google.com/d/msgid/clojure/5a4ad6dc-922a-42ff-b058-faaa94219553%40googlegroups.com. For more options, visit https://groups.google.com/d/optout.