The Case for Exceptions Part 1: Introduction
One of the criticisms levelled at C++ is that its large and complex feature set can be difficult to master, and as someone who’s been programming primarily in C++ for over 15 years and is still discovering new and exciting aspects of the language that’s certainly a viewpoint I can relate to.
That said, my personal belief is that it is this broad feature set that allows you to choose exactly the right tools for the job at hand. In order to be able to do that, you need to understand the benefits and drawbacks of each feature - when it will help and when it will hinder you.
One of the features I often see criticised is the exception. Google, for example prohibit exceptions in C++ code and the ever prolific Joel Spolsky wrote an article some twelve years ago lamenting their use (disclaimer: I have no idea if he still holds the same opinion). Even Raymond Chen of Microsoft considers exceptions to be “too hard”. Other authors make similar arguments 12.
These authors all make good arguments as to why they don’t like exceptions, and yet exceptions as a feature are prolific in almost all modern languages - so there must be something to this idea if it keeps kicking around. In this article I would like to address some of the issues with exceptions and explain why I think they should be used.
The main arguments against exceptions boil down to
- Difficulty in identifying “good” error handling code.
- Difficulty in analysing the code path that might be followed when an error occurs.
- The potential for data to be left in an inconsistent state.
- Decrease in performance.
Whilst the arguments for them are
- More clarity in the primary flow of control.
- Improved transfer of information from the error site to the handling site.
- Stronger object invariants because constructors can fail.
- Exception safe code does not need to know anything about the errors that can occur if it has no reasonable way to handle them.
These points have been argued by (amongst others) David Abrhams and Marshall Cline (see also, the C++ Super-FAQ).
In the rest of this series I will go into more detail on the pros and cons of exceptions, and try to explore real examples and alongside my own opinions.