More importantly my reason is that if you don't believe that you can write defect free code you will never be able to.
Let us start with understanding some ground rules of my claim.
- There is an implicit assumption that the computer you are running on is not subject to an out of spec environment, such as excessive heat or solar flares and that all the hardware is functioning properly.
- Second there is an assumption that the operating system is bug free with respect to the code you are writing.
- Further, it is assumed that the compiler you are using generated correct bug free code with respect to the software you are writing.
When you write code you will almost certainly introduce bugs. Occasionally, I write a small amount of code that is bug free. Just as you can type words that are spelled correctly that form grammatically correct sentences it is possible to write multiple lines of code that are bug free without modification.
Take this with an aggressive stance on bug fixing and testing and you should be able to write small amounts of code that are bug free after only a few iterations.
An approach that I find that works is to fix every bug in code that I'm designing from scratch. The quicker I do this the faster the code becomes solid. It can be harder if you are a maintainer of code to do this as it means that you need to understand both what the code is doing and what the writer of the code intended. It is very difficult to determine intent if you don't have written requirements.
Written requirements are sometimes hard because they often change as you write code. This is due to the discovery process inherent in writing code to solve a problem that you don't fully understand at the start. It can be hard to develop the discipline to update requirements as they change over time. Creating a process with independent testing can help to make this happen. Even so some things will likely fall through the cracks.
The good news though is that even though not having a requirement makes determining the intent of the writer of the code hard to determine, it is often possible to determine based on how the code is used and using engineering judgment.
But, our goal is to leave the software we write in a bug free state when it is complete and for whatever reasons we move on to something new and leave the maintenance to someone else. If this happens the maintainers job is an easy one as they should never need to update the software because it just plain works.
More than likely if the software needs to be updated it would be to extend functionality which builds on the already solid core, which makes the maintainers job a lot easier.
At this point I imagine that you are probably still not convinced that it is possible to write bug free software.
If you can't believe that you can write bug free software you never will.
Unfortunately, I cannot lay claim to having zero defects in all the software I have written. But I can claim that some of the software I have written has zero defects and that over the years I have gotten better at writing software with zero defects.
Obviously, some things cannot be fixed quickly, or are inherited from the underlying system. While this is unfortunate, at the very least one can document that the defect exists so that a user of your software can make an informed decision about how to handle the problem.
This probably sounds overly idealistic. But there are things that over the years have led to countless problems in software.
In the end while I don't expect that you or I will deliver all software with zero defects. I do think that we can deliver some software with zero defects and for the software that has defects we can continue to fix the problems as they are discovered and with time iterate it to zero defects.
The problem with a less idealistic approach is that it leads inexorably to a point where you are spending all of your time fixing bugs in old code you wrote and not fixing bugs in new code. Bug debt or technical debt of this sort has a compounding effect which can only be corrected by either paying down the debt or by declaring technical bankruptcy and abandoning the debt laden code.
I hope that this inspires you to at least improve the quality of the code you write.