A magazine where the digital world meets the real world.
On the web
- Home
- Browse by date
- Browse by topic
- Enter the maze
- Follow our blog
- Follow us on Twitter
- Resources for teachers
- Subscribe
In print
What is cs4fn?
- About us
- Contact us
- Partners
- Privacy and cookies
- Copyright and contributions
- Links to other fun sites
- Complete our questionnaire, give us feedback
Search:
Bugs
by Paul Curzon, Queen Mary University of London
Bugs are everywhere, but why not learn from the mistakes of others. Here are some common bugs with examples of how they led to it all going terribly wrong.
Here is our countdown of the top 10.
BUG 10: Divide by Zero
The USS Yorktown heralded a new generation of "smart" ship. Its propulsion system failed leaving it "dead in the water" for 3 hours after it tried to divide by zero crashing every computer on the ship's network.
BUG 9: Arithmetic Overflow
Keep adding to an integer variable and you run out of bits. Suddenly you have a small number not the bigger one expected. This was one bug in the Therac-25 radiation therapy machine that killed patients. The Boeing 787 Dreamliner had the same problem. Fly for more than 248 days and it would switch off.
BUG 8: Timing Problems
AT&T lost $60 million the day the phones died (all of them). It was a result of changing a few lines of working code. Things happened too fast for the program. The telephone switches reset but were told they needed to reset again before they'd finished, ... and so on.
BUG 6.99999989: Wrong numbers in a lookup table
Intel's Pentium chip turned out not to be able to divide properly. It was due to a wrong entry in a lookup table. Intel set aside $475 million to cover replacing the flawed processors. Some chips were turned in to key rings.
BUG 6: Wrong units
The Mars Climate Orbiter spent 10 months getting to Mars ...where it promptly disintegrated. It passed too close to the planet's atmosphere. The programmers assumed numbers were in pound-force seconds when they were actually in newton-seconds.
BUG 5: Non-terminating loop
The spinning pizza of death is common. Your computer claims to be working hard, and puts up a progress symbol like a spinning wheel...forever. There are lots of ways that this happens. The simple version is that the program has entered a loop in a way that means the test to continue is never false.
BUG 4: Storing a big number in a small space
The first Ariane 5 rocket exploded at a cost of $500 million 40s after lift-off. Despite $7 billion spent on the rocket, the program stored a 64 bit floating point number in to a variable that could only hold a 16 bit integer.
BUG 3: Memory Leak
Memory leaks (forgetting to free up space when done with) are responsible for many computer problems. The Firefox browser had one. It was infamous because Firefox (implausibly) claimed their program had no memory leaks.
BUG 2: Memory Leak
Tony Hoare who invented the null pointer (a pointer that points nowhere) called it his "billion-dollar" mistake because programmers struggle to cope with it. Null pointer bugs crash computers, give hackers ways in and generally cause chaos.
BUG 1: Buffer overflow
The Morris Worm, an early Internet worm, came close to shutting down the Internet. It used a buffer overflow bug in network software to move from computer to computer shutting them down.
BUG 0: Buffer overflow
Arrays in many languages start from position 0. This means the last position is one less than the length of the array. Get it wrong... as every novice programmer does at some point ... and you run off the end. Oddly (in Europe), we have no problem in a lift pressing 1 to go to the second floor up. In other situations, count from 0 and you do one too many things.
OOPS!
More on...
A recipe for ProgrammingFor teachers...
Resources including a slide deck of bugsBrought to you by the Queen Mary University of London team at the Institute of Coding