Java如何查找方法被调用的次数

标签 java eclipse-jdt

我需要找出类中的每个方法被调用了多少次。需要分析的源码如JDK源码。
我使用 eclipse JDT。该程序的工作方式是通过 JDK 源目录。它加载源代码并从中创建一个编译单元。然后我打印出所有完全限定的方法名称。即 package.class.method 名称。

现在我需要找出在其他源文件中调用了多少次 package.class.method。如果可以,请提供源代码。

这是我到目前为止编写的代码:

/*
 * To change this license header, choose License Headers in Project Properties.
 * To change this template file, choose Tools | Templates
 * and open the template in the editor.
 */
package methodcallcounter;

import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.io.IOException;
import java.util.ArrayList;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
import org.eclipse.jdt.core.IMethod;
import org.eclipse.jdt.core.IType;
import org.eclipse.jdt.core.JavaModelException;
import org.eclipse.jdt.core.Signature;

import org.eclipse.jdt.core.dom.AST;
import org.eclipse.jdt.core.dom.ASTNode;
import org.eclipse.jdt.core.dom.ASTParser;
import org.eclipse.jdt.core.dom.ASTVisitor;
import org.eclipse.jdt.core.dom.Block;
import org.eclipse.jdt.core.dom.CompilationUnit;
import org.eclipse.jdt.core.dom.Expression;
import org.eclipse.jdt.core.dom.IMethodBinding;
import org.eclipse.jdt.core.dom.ITypeBinding;
import org.eclipse.jdt.core.dom.MethodDeclaration;
import org.eclipse.jdt.core.dom.MethodInvocation;
import org.eclipse.jdt.core.dom.TypeDeclaration;

public class MethodCallCounter {


    //use ASTParse to parse string
    public static CompilationUnit parse(String str, String fileName) {
        ASTParser parser = ASTParser.newParser(AST.JLS3);
        parser.setSource(str.toCharArray());
        parser.setResolveBindings(true);
        parser.setStatementsRecovery(true);
        parser.setBindingsRecovery(true);
        parser.setKind(ASTParser.K_COMPILATION_UNIT);
        parser.setUnitName(fileName);

        final CompilationUnit cu = (CompilationUnit) parser.createAST(null);

        return cu;
    }

    //read file content into a string
    public static String readFileToString(String filePath) throws IOException {
        StringBuilder fileData = new StringBuilder(1000);
        BufferedReader reader = new BufferedReader(new FileReader(filePath));

        char[] buf = new char[10];
        int numRead = 0;
        while ((numRead = reader.read(buf)) != -1) {
            String readData = String.valueOf(buf, 0, numRead);
            fileData.append(readData);
            buf = new char[1024];
        }

        reader.close();

        return fileData.toString();
    } 

    public static void listf(String directoryName, ArrayList<File> files) {
        File directory = new File(directoryName);

        // get all the files from a directory
        File[] fList = directory.listFiles();

        for (File file : fList) {
            if (file.isFile()) {
                files.add(file);

            } else if (file.isDirectory()) {
                listf(file.getAbsolutePath(), files);
            }

        }
    }

    /**
     * @param args the command line arguments
     */
    public static void main(String[] args) throws IOException, JavaModelException {

        ArrayList<File> al = new ArrayList<File>();
        ArrayList<CompilationUnit> cul = new ArrayList<CompilationUnit>();

        String dirPath = "C:\\Java\\SRC\\";
        listf(dirPath, al);

        for (File f : al) {
            cul.add(parse(readFileToString(f.getAbsolutePath()), f.getAbsolutePath()));
        }

        for (CompilationUnit c : cul) {
            try { 
                List<TypeDeclaration> types = c.types();

                for (TypeDeclaration object : types) {
                    if (object.getNodeType() == ASTNode.TYPE_DECLARATION){
                        String s = c.getPackage().getName().getFullyQualifiedName() + "." +
                            object.getName().getFullyQualifiedName();

                        MethodDeclaration[] meth = object.getMethods();
                        for (MethodDeclaration m : meth) {
                            //
                            System.out.println(s + " " +m.getName().getFullyQualifiedName());
                        }
                    } 
                } 

            } catch (NullPointerException ex) {
                System.out.println("Error : " + c.toString());
            }
        }
    }

}

最佳答案

如果您确切地知道要搜索的文本,您可以重定向控制台输出,您可以在 linux 上使用 grep 和 wc 命令来实现,像这样执行:

java mainclass | grep "searchpatterntomethodname" | wc -l

在 Windows 系统上,您有一个名为 findstr 的工具,相当于 grep,find 相当于 wc。有了这个,您将过滤执行输出到搜索模式并计算行数,这必须与方法调用相同

关于Java如何查找方法被调用的次数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40677167/

相关文章:

java - Java中从非捕获组中提取捕获组

java - Spring 限制最大 session 数;限制最大用户数

java - Hadoop DistributedCache 对象在作业期间更改

java - 比较 Java 中 vector 和数组之间的功能

java - Oracle 数据库元数据的 NUMBER 数据类型的默认值有什么意义吗?

java - 如何使用 JDT 构建调用图

eclipse - 创建 Eclipse 调试 View

eclipse - 禁用部分Javadoc的Eclipse代码格式

eclipse-plugin - JDT中如何获取某个方法的所有可见变量

java - 如何以编程方式使用 Intellij IDEA 代码格式化程序?