# On one of the code quality metrics

By , 18 Oct 2012
 Sign Up to vote
Add a reason or comment to your vote: x
Votes of 3 or less require a comment

There are different metrics used in programming, including metrics for code equality estimation. One of these is the error density metric. One might think it enables one to find out exactly whether or not a certain code is quality. Is it so?

The density of errors in code is quite simple to calculate. You need to take the number of errors and divide it by the number of code lines. For example, if the code contains 6 errors per 100 lines, the error density is 6/100=0.06. This is surely a rather poor code - at the level of a lab work by a novice student.

When using static code analysis one feels the urge to use this metric regularly. Assume, for instance, a static code analyzer generates 10 messages per 1000 code lines. Does it tell you anything about the quality of the code being checked? Unfortunately, it tells you not that much as you might think. Let's see why.

Consider a simple example containing two potential buffer overflows:

int _tmain(int argc, _TCHAR* argv[]) {
char buf[4];

printf("Enter your name: ");
scanf("%s", buf);
printf("Name: %s\n", buf);

printf("Enter your surname: ");
scanf("%s", buf);
printf("Surname: %s\n", buf);

return 0;
}

Buffer overflows are possible (and will most likely occur) in the lines with scanf. The error density is: 2/10=0.2.

But if we take out the reading operation as a single function, the "errors" will become fewer, i.e. we'll have only one:

void my_scanf(char buf[]) {
scanf("%s", buf);
}

int _tmain(int argc, _TCHAR* argv[]) {
char buf[4];

printf("Enter your name: ");
my_scanf(buf);
printf("Name: %s\n", buf);

printf("Enter your surname: ");
my_scanf(buf);
printf("Surname: %s\n", buf);

return 0;
}

Although the program has become no safer, the error density is lower almost twice: 1/13= 0.08! At the same time, those two potential buffer overflows are still there in the code.

Of course, it doesn't mean that the error density metric is useless. The mentioned effect will be compensated for in large code amounts. But remember to be careful with this metric.

## License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)

## About the Author

Russian Federation

We develop the PVS-Studio static code analyzer for C/C++/C++11.

PVS-Studio is a static code analyzer for C/C++ (Visual Studio 2005/2008/2010) with a simple licensing and pricing policies which is easy to install and use without need to deploy a complex maintenance environment.

Follow on

## Comments and Discussions

 First Prev Next
 This an analysis fault not a metric fault Nick Hounsome 18-Oct-12 21:52
 Last Visit: 31-Dec-99 18:00     Last Update: 10-Dec-13 7:45 Refresh 1

General    News    Suggestion    Question    Bug    Answer    Joke    Rant    Admin

| Advertise | Privacy | Mobile
Web02 | 2.7.131209.1 | Last Updated 18 Oct 2012
Article Copyright 2012 by viva64.com
Everything else Copyright © CodeProject, 1999-2013
Terms of Use
Layout: fixed | fluid