统计java方法(函数)的代码行数

今天想对一个java项目超过100行的方法进行一些代码优化。需要统计一下项目中的java类有哪些方法的代码超过了100行。在网上没找到类似的统计工具,就自己写了段代码进行统计。

编码思路:因为一个java类,最外层的{}可以标识类,次外层的{}就是方法或内部类了。为了便于编码,我把内部类也当作方法处理了。只要把次外层的{和}配对就是一个完整的方法了。因此我用先进后出的栈存储一个数组。数组的第一个元素是某个方法起始行,第二个元素是该行的行号。这样既能通过行号相减得到方法的行数,又能记录方法的位置。

具体代码如下:


package query;

import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.io.IOException;
import java.util.Stack;


public class StatNumForMethod {
public static void main(String[] args) {
File dir = new File("E:/workspace/XXX/src/main/java/");//要统计的java包的绝对路径

ergodicDir(dir);

}


/**
* 遍历目录下的所有java文件
* @param dir
*/
private static void ergodicDir(File dir) {
if(dir.isDirectory()){
for(File file : dir.listFiles()){
if(file.isDirectory()){
ergodicDir(file);
}

if(file.isFile() && file.getName().endsWith("java")){
statInFile(file);
}

}
}
}


private static void statInFile(File file) {
BufferedReader reader = null;
try {
//读一个文件输入流
reader = new BufferedReader(new FileReader(file));
String line = null;
Stack<String[]> stack = new Stack<String[]>();
int lineNum = 0;

while((line=reader.readLine()) != null){//遍历行
lineNum++;
//遇到{时把当前行和行号作为数组的元素进栈,遇到}时计算出方法的行数并打印行,出栈
int matchNum = getOccur(line, "{")-getOccur(line, "}");//一行可能有多个{或}
if(matchNum > 0){
for(int i=0;i<matchNum;i++){
stack.push(new String[]{line, lineNum+""});
}
}else{
for(int i=0;i<-matchNum;i++){
if(stack.isEmpty()){
System.out.println(file.getName()+"文件的{}不匹配,不能统计行数。。。当前的行号是"+lineNum);
return;
}
String[] popArr = stack.pop();
if(stack.size()==1){//当栈大小为1时说明一个方法结束了
int beginNum = Integer.parseInt(popArr[1]);//方法开始的行号
if(lineNum-beginNum >100){//方法内的代码超过100行
System.out.println(file.getName()+"文件的"+popArr[0]+"方法(第"+beginNum+"行)多达"+(lineNum-beginNum+1)+"行");
}
}
}
}
}
} catch (Exception e) {
e.printStackTrace();
}finally{
if(reader != null){
try {
reader.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}

/**
* src 源,find 查找目标,返回的就是找到的数目
* @param src 源
* @param find 查找目标
* @return 找到的数目
*/
private static int getOccur(String src, String find) {
int o = 0;
int index = -1;
while ((index = src.indexOf(find, index)) > -1) {
++index;
++o;
}
return o;
}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值