Bindings, Platforms, and Innovation
This presentation focuses on the Internet and separating myth from fact, history from the future, and the mundane from the imaginative. Bob Frankston presents a vision of what could and should be.
Tracking change and innovation in the enterprise software development community
Posted by Amr Elssamadisy on Apr 05, 2007 05:27 AM
A good design is elegant and simple - but elegance is in the eye of the beholder. James Shore, in his book The Art of Agile Development, disagreed with this abstract concept. In fact, he provided a very concrete definition of design quality: "A good software design minimizes the time required to create, modify, and maintain the software while achieving run-time performance."In fact, our computers are so fast, modern languages actually waste computing resources. With an optimizing compiler, C is just as good as assembly language. C++, though, adds virtual method lookups... four bytes per method and an extra level of indirection. Java and C# add a complete intermediate language that runs in a virtual machine atop the normal machine. Ruby interprets the entire program on every invocation!Shore then went on to assert that good design (not just software design) is the “art of maximizing the benefits of our tradeoffs”. This led directly to the thought-provoking definition of design above: "A good software design minimizes the time required to create, modify, and maintain the software while achieving run-time performance."
How wasteful.
With such waste, why is Ruby on Rails so popular? How is it possible that Java and C# could succeed? What do they provide that makes their waste worthwhile? Why aren't we all programming in C?
Equating good design with the ease of maintenance is not new, but stating it this way leads to some interesting conclusions:If the object of good design is to minimize the amount of developer time, then an application that is easily built and maintained by a group of developers who know and understand java will be a good design. The same application will be considered a very poor design for a group of C++ programmers. The same design has different quality that is dependent upon the programmers writing and maintaining the code.
1. Design quality is people-sensitive.
2. Design quality is change-specific.Design quality being change-specific is nothing new. That is good – this new definition doesn’t contradict what we already know – it adds to it. There are two general ways to make designs of higher quality with respect to this aspect: generalizing ala’ tools like design patterns, and using tests and refactoring as change-enablers. An interview with Erich Gamma is very informative when it comes to this trade-off.
3. Modification and maintenance time are more important than creation time.This, again, is nothing new. We know that time spent in maintenance is much more than creation time of an application. Add to this, in iterative development, modification happens during the initial creation of the application, and we have even more reason to focus on this issue.
4. Design quality is unpredictable.By the above definition, quality is really dependant on the team developing the software. As the team changes, or evolves, then the design quality also evolves. It is therefore unpredictable. You really only know how good a design is by it standing the test of time and modifications.
Agile Development: A Manager's Roadmap for Success
Effective Management of Static Analysis Vulnerabilities and Defects
Ensuring Code Quality in Multi-threaded Applications
The Agile Business Analyst: Skills and Techniques needed for Agile
This presentation focuses on the Internet and separating myth from fact, history from the future, and the mundane from the imaginative. Bob Frankston presents a vision of what could and should be.
This article explores the use of JBoss and jBPM to implement design solutions that effectively address the issue of orchestrating long running activities.
This presentation covers the use of graph databases as an optimal solution for data that is difficult to fit in static tables, rapidly evolving data or data that has a lot of optional attributes.
This session introduces Real Options and shows how it can help in running your project. Real Options is a decision-making process that can be used to manage risk.
This article discusses the use of bindings on services and references (including the instance of non-configured bindings) as the means to implement SCA communications in a Web and SOA environment.
After a short introduction to DSLs, Scott Davis plays with the keyboard showing how to approach the creation of a DSL by typing working snippets of Groovy code that get executed.
IBM Rational and InfoQ present, Scaling Agile with C/ALM, an eBook showing organizations how to become “finely tuned software delivery machines” by enabling team integration and scaling.
Amanda Laucher presents a real life enterprise application written in F#. She shows actual code snippets, explaining design decisions and suggesting how to use some of the F# constructs.
No comments
Watch Thread Reply