How to Build Great Software

By: Chris Graham
Submitted: 2007-01-17 15:53:52
Print this article | Tell a friend | For publisher | Social Bookmarking
Rating:
 

In this article I'm going to explain the top 10 software development fallacies my company avoids. By avoiding these myths and concentrating on excellence, we are able to make great quality software.

Myth 1) Software must be designed in detail before development starts, so that a clear plan can be out-layed.

The truth) The more complex a design, the more like software the design itself is. By perfecting a design, then writing the software to that design, you're effectively writing the work twice. Instead, by doing just some simple design sketches and data modelling rather than a book-like design, a good development team can create a shell for the software and efficiently refine it towards the finished product. This process of refinement creates natural prototypes, allows easy adaptation when issues that would be unforseen by a design arise (or brought up as fresh concerns by a client), and the total process takes significantly less time. To pull this off requires a close team, skill, and experience, but it is by far the best option for the majority of situations.

Myth 2) There are programmers, designers, analysts, and users.

The truth) By structuring development so that all developers get some exposure to each part of the development process, skills may be shared and greater insight may be gained. If developers are encouraged to actually use the software then they can use that expertise to think of improvements that otherwise would not come to light.

Myth 3) A happy team is a productive team.

The truth) A team of people with a wide variety of natural skills, experience and concern, that criticises each other and argues vehemently over the smallest details, will bring up and resolve issues that otherwise would never be tackled. A furnace of relentless argument is the best way to forge understanding and reach perfection.

Myth 4) It's important we understand our direction and don't compromise with it.

The truth) Life is compromise, and compromise is not a weakness. There will always be issues (such as efficiency, budget, ease-of-use, power, scope, and the need for easy internationalisation) that cannot be simultaneously met without such compromise.

Myth 5) We know what the client wants, we know what the issues are.

The truth) Without constant re-evaluation, it is easy to lose track of the objective. Developers are often faced with problems to solve that they consider the issues, when those are in fact separated from the actual market goals and can become totally irrelevant. Developers must always understand the market goals and be able to adapt when other things change, or even the goals themselves change.

Myth 6) Bigger is better. Features are cool.

The truth) Features can easily confuse users, and their actual value should always be considered against the cost of confusion. In some cases it is sensible to actually remove working features due to such concerns.

Myth 7a) The customer is always right.

The truth) Most customers try hard not to look ignorant in front of software developers, and hence phrase their suggestions in a technical way. The effect is that often suggestions aren't really appropriate, because they're not founded on a solid understanding of technical issues.

Myth 7b) The customer is often wrong.

The truth) Although customers needs are often not best met by doing literally what they say, they always know what they want and why they want it - and usually for very good reason. Understand them and adapt what they say, discuss with them, but never ignore them.

Myth 8) Comment your code a lot.

The truth) Good code needs hardly any commenting, because sensible uses of naming and white-space are better alternatives. Comments should only ever explain the non-obvious, or provide standard API documentation.

Myth 9) Such and such is needed, such and such is great.

The truth) A bad workman blames his tools. Whilst some development tools aid development substantially, a good developer can do great results in most things served to them. There are a few exceptions, like Microsoft Access, or assembly language, but generally speaking the difference in quality results is much more due to the skills of the developers than the quality of their tools.

Myth 10) The customer will understand if there's an efficient and easy-to-use interface.

The truth) The interface doesn't just need to be easy-to-use, it needs to be navigatable without an overall systems understanding. Screens need to be self-describing.

Managing Director of ocProducts, a company specialising in software (ocPortal) to help people build a website.

Article source: Expert Articles

Most Recent Articles in Software category

  • "Black Hat Search Engine Optimization Techniques" - a risky job. - By: McRaaN Systems
    Black Hat Search Engine Optimization are those SEO techniques which are deemed to be clever, sneaky, deceptive, underhand and even dishonest and generally practices that are not endorsed by the search engines or to break search engine guidelines, such as ..
  • DRM Advantages - By: Alice Pierce
    Every technology is assessed on the basis of the advantages it provides. DRM provides advantages not only for the owners, but also for the providers as well as the end users.
  • The DRM controversies - By: Alice Pierce
    Invention of new technologies has always been connected with some controversies or other. DRM has been no exception to this common rule though most of the controversies are based on assumptions only.
  • Legal aspects of DRM use - By: Alice Pierce
    Legal aspects of DRM use and violations are closely related to copyright violations. Not only in United States and Europe but throughout the world there is conscious efforts to standardize the laws relating to DRM.
  • Document security, E Books, and DRM protection - By: Alice Pierce
    E books were starting to loose their popularity due to restrictions used by the publishers through DRM protection system. However, the publishers have now found out DRM method that compromises user requirements with publishers' interests
  • Protecting audio and Internet music with DRM - By: Alice Pierce
    Like films audio music is also vulnerable to unauthorized copying. DRM as prevention has its own problem and yet is the best possible solution to address the problem of copying.
  • Preventing movie piracy with DRM - By: Alice Pierce
    Movies have always been the object of piracy despite poor quality of the copies. However the advent of digital technologies has completely changed the scenario with high quality copies that needs prevention.
  • DRM and Analog-Digital conversion - By: Alice Pierce
    Enhanced capabilities among individuals and all concerned for analog digital conversion has turned out to be a major threat for copyright dependent producers of web contents. Use of DRM therefore can not be termed as unethical.
  • Digital rights management - companies and controversies - By: Alice Pierce
    Document security and copy protection are very crucial aspects of any organization. The copy protection is important for PDF documents as well as web based content security.
  • Access control with DRM software - By: Alice Pierce
    To prevent your intellectual properties from being stolen you must control access to them. This is exactly the function of digital rights management that is tending to replace the traditional print copyright system.