Introduction

What is an error? The short answer is, “Something that’s expensive to fix.” Dealing with errors is costly in terms of both money and time. As you probably know already, your test cycle will be longer, more complex, and less effective if you don’t build appropriate error handling into your code right from the start. For these reasons alone, you should do all you can to reduce and handle errors in order to reduce costs, deliver quality code, and keep to schedules.

One way to eradicate errors—a way that I’ll dismiss immediately—is to write error-free code. I don’t think it’s generally possible to write such pristine code. A more realistic way to deal with errors effectively is to plan for them properly so that when they do occur:

So what must we do to put a good error handling scheme in place? It’s a deceptively simple question with a deceptively big (subjective) set of answers. I think that acquiring and then using some fundamental knowledge is where we should start:

Handling errors properly in Visual Basic is also a good idea because of the alternative: Visual Basic’s default error handling rules are rather severe. Unhandled errors are reported, and then an End statement is executed. Keep in mind that an End stops your application dead—no form QueryUnload or Unload events, no class Terminate events, not much of anything in fact.

To help you develop an effective strategy for dealing with errors, I’ll go over some concepts that I consider vital to the process. These are presented (in no particular order) as a series of tips. “Pick ’n mix” those you think will suit you, your company, and, of course, your development project. Each tip is empirical, and we have employed them in the code we write at The Mandelbrot Set (TMS). I hope they serve you as well as they have served us!