[ package ] [ object ] [ method ] [ explanation ]
The following document contains the results of a JavaNCSS metric analysis.[ package ] [ object ] [ method ] [ explanation ]
Packages sorted by NCSS.
Package | Classes | Methods | NCSS | Javadocs | Javadoc lines | Single lines comment | Multi lines comment |
---|---|---|---|---|---|---|---|
javancss | 11 | 137 | 1261 | 66 | 440 | 90 | 322 |
javancss.test | 3 | 40 | 444 | 9 | 47 | 46 | 52 |
Classes total | Methods total | NCSS total | Javadocs | Javadoc lines | Single lines comment | Multi lines comment |
---|---|---|---|---|---|---|
14 | 177 | 1705 | 75 | 487 | 136 | 374 |
[ package ] [ object ] [ method ] [ explanation ]
TOP 30 classes containing the most NCSS.
Object | NCSS | Methods | Classes | Javadocs |
---|---|---|---|---|
javancss.Javancss | 359 | 41 | 1 | 10 |
javancss.test.JavancssTest | 358 | 25 | 0 | 4 |
javancss.JavancssAntTask | 302 | 45 | 0 | 46 |
javancss.JavancssFrame | 198 | 9 | 0 | 2 |
javancss.AsciiFormatter | 130 | 12 | 0 | 1 |
javancss.XmlFormatter | 108 | 12 | 0 | 1 |
javancss.test.XmlFormatterTest | 38 | 7 | 0 | 4 |
javancss.Metric | 24 | 6 | 0 | 1 |
javancss.test.AbstractTest | 22 | 8 | 0 | 1 |
javancss.PackageMetric | 19 | 3 | 0 | 1 |
javancss.ObjectMetric | 11 | 2 | 0 | 1 |
javancss.Main | 9 | 1 | 0 | 1 |
javancss.FunctionMetric | 7 | 2 | 0 | 1 |
javancss.Formatter | 5 | 4 | 0 | 1 |
TOP 30 classes containing the most methods.
Object | NCSS | Methods | Classes | Javadocs |
---|---|---|---|---|
javancss.JavancssAntTask | 302 | 45 | 0 | 46 |
javancss.Javancss | 359 | 41 | 1 | 10 |
javancss.test.JavancssTest | 358 | 25 | 0 | 4 |
javancss.AsciiFormatter | 130 | 12 | 0 | 1 |
javancss.XmlFormatter | 108 | 12 | 0 | 1 |
javancss.JavancssFrame | 198 | 9 | 0 | 2 |
javancss.test.AbstractTest | 22 | 8 | 0 | 1 |
javancss.test.XmlFormatterTest | 38 | 7 | 0 | 4 |
javancss.Metric | 24 | 6 | 0 | 1 |
javancss.Formatter | 5 | 4 | 0 | 1 |
javancss.PackageMetric | 19 | 3 | 0 | 1 |
javancss.FunctionMetric | 7 | 2 | 0 | 1 |
javancss.ObjectMetric | 11 | 2 | 0 | 1 |
javancss.Main | 9 | 1 | 0 | 1 |
Averages.
NCSS average | Program NCSS | Classes average | Methods average | Javadocs average |
---|---|---|---|---|
113.57 | 1,705.00 | 0.07 | 12.64 | 5.36 |
[ package ] [ object ] [ method ] [ explanation ]
TOP 30 Methods containing the most NCSS.
Averages.
Program NCSS | NCSS average | CCN average | Javadocs average |
---|---|---|---|
1,705.00 | 8.35 | 2.39 | 0.34 |
[ package ] [ object ] [ method ] [ explanation ]
Non Commenting Source Statements (NCSS)
Statements for JavaNCSS are not statements as specified in the Java Language Specification but include all kinds of declarations too. Roughly spoken, NCSS is approximately equivalent to counting ';' and '{' characters in Java source files.
Not counted are empty statements, empty blocks or semicolons after closing brackets. Of course, comments don't get counted too. Closing brackets also never get counted, the same applies to blocks in general.
Examples | |
---|---|
Package declaration | package java.lang; |
Import declaration | import java.awt.*; |
Class declaration |
|
Interface declaration | public interface Able ; { |
Field declaration |
|
Method declaration |
|
Constructor declaration | public Foo() { |
Constructor invocation |
|
Statement declaration |
|
Label declaration | fine : |
In some cases consecutive semicolons are illegal according to the JLS but JavaNCSS still tolerates them (thought JavaNCSS is still more strict as 'javac'). Nevertheless they are never counted as two statements.
Cyclomatic Complexity Number (CCN)
CCN is also know as McCabe Metric. There exists a much hyped theory behind it based on graph theory, but it all comes down to simply counting 'if', 'for', 'while' statements etc. in a method. Whenever the control flow of a method splits, the "CCN counter" gets incremented by one.
Each method has a minimum value of 1 per default. For each of the following Java keywords/statements this value gets incremented by one:
Also if the control flow of a method returns abortively the CCNvalue will be incremented by one:
An ordinary return at the end of method will not be counted.
Note that 'else', 'default', and 'finally' don't increment the CCN value any further. On the other hand, a simple method with a 'switch' statement and a huge block of 'case' statements can have a surprisingly high CCN value (still it has the same value when converting a 'switch' block to an equivalent sequence of 'if' statements).