码迷,mamicode.com
首页 > 编程语言 > 详细

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

时间:2015-07-20 13:00:06      阅读:235      评论:0      收藏:0      [点我收藏+]

标签:方法行数   函数大小   

今天想对一个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;
}

}

版权声明:本文为博主原创文章,未经博主允许不得转载。

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

标签:方法行数   函数大小   

原文地址:http://blog.csdn.net/keketrtr/article/details/46966003

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!