今天想对一个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;
}
}
版权声明:本文为博主原创文章,未经博主允许不得转载。