Reputation: 519
I'd like to analyze and understand a certain Java app and I think a call graph would be very useful. How do I generate one? I'm using Eclipse.
Upvotes: 17
Views: 24001
Reputation: 21
You cannot get a graph for the entire code in eclipse. However, you can get a tree view of callers or callees for a method.
In the source code, right-click on the name of a method of interest, say main(String[] args), then click on Open Call Hierarchy. (Ctrl+Alt+H on Windows)
This will open a tree view of the hierarchy of callers (Caller Hierarchy). There is an option to view the Callee Hierarchy.
To copy to a text file, right-click on a node in the Call Hierarchy view and click on Copy Expanded Hierarchy.
Drawbacks:
Upvotes: 2
Reputation: 2455
I had exactly the same problem, so I 've written the java-callgraph suite of tools. Using it, you can create both dynamic (runtime) call graphs and static call graphs, provided that you have the program's and its dependencies' jar files.
Upvotes: 13
Reputation: 2765
Thread.dumpStack() allows you to output the current call stack without throwing an exception or using a debugger. This will be output to the console.
You could put a call to dumpStack() in "hotspots" of your code to get the calling stack the application took to get to that point.
Upvotes: 1
Reputation: 2001
Netbeans profiler is very good for this !!
The profiling functions include CPU, memory and threads profiling as well as basic JVM monitoring ...
You can also use jconsole command (part of the jdk)
It launches a graphical console tool that enables you to monitor and manage Java applications and virtual machines on a local or remote machine.
Upvotes: 4
Reputation: 13841
Getting callstack
1) If you can debug the application simply put a breakpoint (double click over the left margin of the code) and wait it to stop. Go to Debug Perspective if you're not there, and open the Call stack View/Panel. It has the call stack :)
2) If you want to print this stack trace somewhere use an Exception:
Exception aux = new Exception("I'm here"); // not for throwing!
aux.printStackTrace(); // if you want it in stdout
or
Exception aux = new Exception("I'm here"); // not for throwing!
StringWriter sw = new StringWriter();
aux.printStackTrace(new PrintWriter(sw));
String result = sw.toString(); // if you want it in a string
Obtaining method references
You can obtain all references to a method by right-clicking, References, Workspace. It will search all callings in your current open projects. Very very useful.
Profiling an app
(thanks those who had answered the profiler option)
Eclipse TPTP provides profiling:
http://www.eclipse.org/tptp/home/project_info/general/whatisTPTP.php
Upvotes: 14
Reputation: 4587
Fast and dirty, create a new exception and print the stacktrace.
Exception e = new Exception();
e.printStackTrace();
Upvotes: 2