我正在使用Google javaparser来解析java文件,当我尝试计算“If”语句时,似乎我无法获得“else-if”语句的数量。
例如,我想解析以下代码:
if(i>1){
i++;
}else if(i>2){
i++;
}else if(i>3){
i++;
}else{
i++;
}
我想获得Cyclomatic的复杂性,以便我需要计算“if”和“else-if”的数量。 当我使用Visitor模式时,我只能访问API中定义的“IfStmt”,代码如下:
private static class IfStmtVisitor extends VoidVisitorAdapter<Void> {
int i = 0;
@Override
public void visit(IfStmt n, Void arg) {
//visit a if statement, add 1
i++;
if (n.getElseStmt() != null) {
i++;
}
}
public int getNumber() {
return i;
}
}
没有办法获得“else-if”,但带有“IfStmt”的访问者模式将整个代码块视为一个“if”Statement.So,我希望该数字为4,但它是2。 / p>
任何人都有一些想法?
答案 0 :(得分:1)
if语句只包含一个“then Statement”和一个“else Statement”。 else语句可以是隐藏的if语句。所以有一个递归。为了跟踪您所需的复杂性,以下递归方法可能有所帮助:
private static class IfStmtVisitor extends VoidVisitorAdapter<Void> {
int i = 0;
@Override
public void visit(IfStmt n, Void arg)
{
cyclomaticCount(n);
}
private void cyclomaticCount(IfStmt n)
{
// one for the if-then
i++;
Statement elseStmt = n.getElseStmt();
if (elseStmt != null)
{
if ( IfStmt.class.isAssignableFrom(elseStmt.getClass()))
{
cyclomaticCount((IfStmt) elseStmt);
}
else
{
// another for the else
i++;
}
}
}
public int getNumber() {
return i;
}
}
希望有所帮助。