|
I’ve found that a great many software
engineers can develop working programs, but do little or no real engineering
design.
Does this sound harsh? Perhaps, but I’ve also
found it hard to deny. I’ve encountered very few software engineers, for
example, who have clean, crisp and readable coding styles—an essential element
of elegant software design. I’ve also encountered a preponderance of cryptically
written functions, clumsy software abstractions and bizarre spaghetti code. To
my dismay, I’ve discovered that even among computer science graduates, many
reduce object-oriented programming to the mere use of private data, public
functions and object instantiations. It’s enough to break a teacher’s heart.
Now, I won’t go so far as to say that most
programmers write spaghetti code. That would not be fair. However, I do think
that relatively few programmers have a deep appreciation for the artistry of
software development. That’s not to say that they’re ignorant of such things;
not at all. Rather, it’s more that the engineering aspects of elegant code
design are all too often neglected.
I think this happens because modern programming
tools have made proper code design seem like a nuisance. In the early years of
computing, people were forced to write out their software designs, pondering
many fine details before they ever sat down in front of the computer. Nowadays,
with our fast compilers and interactive debugging systems, programmers often
find it more convenient to simply sit down and start coding, with just a modicum
of software design. Mind you, I do understand that this is sometimes more
efficient—when the programming task is fairly routine, for example. However,
when such design-as-you-go software development becomes standard practice, then
you have the makings of utter chaos.
In part, this problem is also rooted in the
malleable nature of computer software. No self-respecting civil engineer would
design a bridge by slapping girders together until he has something that works;
after all, if the bridge collapses, it could take months to rebuild it.
Similarly, no sensible architect would want to build a house without blueprints
and floor plans. Yet it is commonplace for programmers to develop software using
poorly chosen functions and only the sketchiest of designs. After all, if the
software doesn’t work, they can always find the bug and fix it—at least, in
theory. In practice, these bugs are often difficult to detect, and fixing them
can require extensive surgery. The consequences of an ill-designed software
program can be disastrous indeed.
For this reason, I believe that high-tech
companies need to give software engineering the respect that it deserves. They
need to develop a true culture of systematic software design, instead of merely
settling for “whatever works.” A company that’s looking toward the future must
pay proper devotion to the principles of software maintainability, proper
documentation and elegant, robust design. It must also inculcate a culture of
true software engineering among its employees. The failure to do so may work in
the short-term, but it is a recipe for long-term disaster.
|