New-age Transactional Systems - Not Your Grandpa's OLTP
John Hugg discusses high volume transaction processing applications with high and low frequency profiles, and how VoltDB can be used for that purpose.
The content has been bookmarked!
There was an error bookmarking this content! Please retry.
Posted by Jon Rose on Nov 13, 2007
Prior to AS3, all type information was stripped out of the code when compiled. At runtime, everything was just dynamically typed atoms. Starting with AS3, we can get the type information all the way down to the runtime.Method Closures
… Using explicitly typed variables can improve performance and reduce memory consumption.
In AS3, we got method closures, which also mean we can create variables that are functions, and pass them around, while the function still retains the environment, it was created within ("this" is still what "this" was, when defined).In Gary Grossman's and Emmy Huang's article, ‘Action Script 3.0 Overview,’ they describe a key usage of Method Closures:
Event handling is simplified in ActionScript 3.0 thanks to method closures, which provide built-in event delegation.Just-in-Time (JIT) Compiler
myButton.addEventListener("click", someMethod);
In practice, the AVM2 may transform the code at run-time by means of a JIT, but this does not affect the semantics of execution, only its performance.Olesen does note one impact developers should consider:
There is one thing to take notice of with JIT in AVM2. Constructors are not JIT'ed, so if you have performance intensive code in a class, take it out of the constructor.Garbage Collection
The memory management and garbage collector is to be found in the separate MMgc project. This is a Deferred Reference Counting (DRC) mechanism combined with an incremental, conservative mark/sweep collector. Of course, the garbage collector implementation has been tuned for best client performance, with small (30ms) time slices.For those looking for additional resources, , Farata Systems has a detailed blog entry comparing the language syntax between Java 5 and ActionScript 3. Also, more information can be found on AVM2 by reviewing the Mozilla Tamarin Project. Tamarin is the AVM2 implementation used in the Flash Player 9 and AIR platform. In addition, Adobe has a community Flex site dedicated to Java Developers at, http://flex.org/java/.
SOA All-In-One Guide: KPIs & Best Practices, ESB Report
Monitor your Production Java App - includes JMX! Low Overhead - Free download
Agile Development: A Manager's Roadmap for Success
Agile Practices to Improve Project Management Organization (PMO) Effectiveness
John Hugg discusses high volume transaction processing applications with high and low frequency profiles, and how VoltDB can be used for that purpose.
Kevlin Henney examines code samples to see what can be learned from them starting from the premise that one won’t write great code unless he knows how to read it.
Jason Ayers share the observations he made watching a team of developers collaborating in real time on the same code base, pushing XP, pair programming and continuous integration to their extremes.
Michael Snoyman presents Yesod, a web framework written in Haskell and containing a web server, templating, ORM, libraries (templating, gravatar, etc.).
Richard Kreuter and Kyle Banker on how to avoid classical RDBMS transactional systems by using compensation mechanisms, transactional messaging or transactional procedures.
Attila Szegedi talks about performance tuning Java and Scala programs at Twitter: how to approach GC problems, the importance of asynchronous I/O, when to use MySQL/Cassandra/Redis, and much more.
One category of risk that project teams need to ensure they address is business value failure – delivering a product that fails to provide value for the business investor.
InfoQ spoke to the authors of Software Systems Architecture on a couple of new topics, the System Context viewpoint and Agile, which have been added to the second edition.
No comments
Watch Thread Reply