IntelliJ IDEA 2024.2 Help

Read the profiler snapshot

The snapshot made with the IntelliJ Profiler configuration can be viewed in the following modes:

  • CPU Time – the subset of samples that corresponds to actual CPU work, excluding IO, waiting on locks, context-switching, and the like. Useful for identifying CPU-intensive sections, where you can get the most benefit from optimizations such as improving algorithm complexity.

  • Total Time – all samples, including those for sleeping threads. This mode is useful to consider perceived performance and actual runtime, including IO, context-switching overhead, synchronization, and so on. With it, you can spot sections that may be slowed down by external factors or suboptimal concurrency.

  • Memory Allocations – the subset of samples that corresponds to memory allocation events. This mode is useful to identify memory-intensive sections, where you can get the most benefit from optimizing the amount of primitives boxing, objects creation, and so on.

Switch viewing mode

  • Use the menu in the top-right corner of the tool window.

    The Show menu in the top-right corner of the Profiler tool window

IntelliJ IDEA provides several views to analyze the snapshot:

  • In-editor hints – an intuitive way to assess the performance of the particular lines of code right in the editor

  • Call tree – a tree representing the code paths and their share in the overall CPU/memory usage

  • Flame graph – a graphic representation of the code paths that facilitates analysis and navigation by representing stack frames as visual elements

  • Method list – a flat view providing aggregated statistics for individual methods rather than code paths

  • Timeline – a visual representation of threads' activity over time

Navigate the snapshot

By default, library and framework methods are shown collapsed. You can expand the collapsed calls by clicking the expand button in the corresponding frame.

Pointing at the 'expand' button in a flame graph's frame

When you focus on a specific method in a tab of the Profiler tool window, IntelliJ IDEA opens the corresponding source in the editor. Also, you can right-click it and select another Profiler tool window tab to open it in.

Jumping between tabs in the Profiler tool window

Threads

The profiling data in the Profiler tool window tabs is grouped by thread. You can select to view merged data for the entire process (All threads merged) or select a specific thread for closer investigation.

Show threads

By default, the list of threads is hidden, and the data is shown for all threads combined.

  • To select a particular thread or review the list of threads, click the Show Threads View in the left-hand toolbar.

The Threads panel in the Profiler tool window

The threads are listed on the left-hand side of the Profiler tool window and sorted by the number of collected samples. Thus, you can find the most busy threads at the top of the list.

Line profiler

When you open a snapshot, IntelliJ IDEA shows the Profiler tool window and adds runtime hints near the corresponding lines right in the editor.

Lines that took a significant amount of time to execute get grey labels, while the most resource consuming methods are marked with red labels with the fire icon.

Line profiler hints appear on opening a snapshot

If you want to drill-down and see what's inside a labeled method, clicking the hint will take you to the method declaration, where you can inspect the implementation for particular lines causing slowness.

Method implementation marked with runtime labels

Flame Graph

The flame graph visualizes the application call tree with the rectangles that stand for frames of the call stack, ordered by width. Frames that consume more resources are wider than the others and are placed on the left.

A portion of the flame graph

For example, we can make the following observations from the flame graph above:

  • The execution time of main() was contributed to by the methods a() and b(). In its turn a() called c().

  • c() is mostly adding elements to an ArrayList, which could take less time if the capacity of the ArrayList was adequate – add is mostly busy growing the list.

  • Most of the time b() is processing IndexOutOfBoundsException. It may be a good idea to analyze where these exceptions come from and see if we can do anything about it.

IntelliJ Profiler uses color-coding to differentiate between the different types of frames:

Frame type

Light theme

Dark theme

Project code

Yellow

Yellow

Library code

Purple

Grey

Native code

Blue

Blue

Color coding for different types of frames on the flame graph

Get call details

  • Hover over a block to see the tooltip with frame details. The tooltip shows the share of time in the entire snapshot and in the frame's direct parent.

    A tooltip with details appears on hovering a frame in the flame graph

Zoom the graph

  • Use the the Zoom in button and the Zoom out button buttons on the flame graph's toolbar or the scroll wheel to zoom the graph.

  • To focus on a specific method, double-click the corresponding block on the graph.

  • To restore the original size of the graph, click 1:1 on the toolbar.

    Buttons to the left of the flame graph allowing you to zoom in and out

Set node threshold

It may be difficult to tell if a node accounts for a substantial portion of time or samples in the snapshot, particularly when the view zoomed in, and the scale is not easily identifiable. In this case, you can set a threshold to grey out nodes that are not heavy enough.

  1. Click the Presentation Settings button and select Show Nodes Filter.

  2. Use the slider to the right of the flame graph. The nodes that do not pass this threshold will appear colorless.

    Setting nodes filter in the Presentation Settings menu
  • If you want to locate a specific method on the graph, start typing its name or click Show Search Toolbar and type the name in the search bar.

    The graph highlights all blocks with method names matching your search request.

    Using the search in the Flame Graph tab

    Use Previous Occurrence and Next Occurrence for fast navigation between search results. Using the buttons on the toolbar, you can also search either the whole graph or a specific subtree and navigate to the results as soon as something was found.

Capture the graph

You can capture and export the graph separately from other data in the snapshot.

  • Click Capture Image and select Copy to Clipboard or click Save to export the graph as an image in the .png format.

Call Tree

The Call Tree tab organizes the sampled data in a tree-like structure.

call tree tab in the profiler results

For each method, the tab shows the following information:

By default, the percentage is relative to the total execution time. You can choose to view the numbers relative to the parent frame.

Switch the percentage between total and parent

  • Click the Presentation Settings button and select Show Percent of Total Time or Show Percent of Parent.

    The Show Percent of Total Time/Parent button in the Presentation Settings menu

Filter Call Tree results

The Call Tree tab allows you to collapse the frames you are not interested in at the moment. For example, you can hide library classes or the classes that come from specific frameworks to focus on the application code.

The blue arrow right after the percentage presents a filtered sequence of calls.

Show filtered calls

Disable filtering

  • Click the Presentation Settings button and deselect the Filter Calls option.

Configure filtering rules

  1. In the Settings dialog (Ctrl+Alt+S) , select Build, Execution, Deployment | Java Profiler | Filters.

    In this dialog, you can modify the existing rules and add new ones.

  2. Configure the packages or specific classes that you want to hide in the output.

    • To filter all methods in a class, specify the fully qualified class name (for example: org.bar.ClassName).

    • To filter specific methods in a class, use the following format: fully qualified class name : method name (for example: * : myMethod()).

Collapse recursive calls

A stack that involves recursion may be very difficult to analyze. In a regular Call Tree view, recursive calls are displayed as they are called – one after another, which may lead to almost infinite stack scrolling.

IntelliJ IDEA detects recursion when the same method is called higher up in the call stack. In this case, the subtree is taken out of the call tree and then attached back to the first invocation of that method. This way you can bypass recursion and focus on methods that consume most of the resources and calls that they make.

Collapsing recursive calls allows you to see the total amount of time spent in these calls as if there was no recursion.

Collapse recursive calls button

Folded recursive calls are marked with the the Recursion icon icon on the Call Tree tab. Click it to open the recursive call tree in a separate tab. You can preview the number of merged calls in the tooltip that appears on hovering over the recursion icon.

What-if: focus on specific methods

IntelliJ IDEA allows you to examine specific nodes and subtrees in the Call Tree: you can exclude particular methods or the other way round, focus only on the nodes in which you are interested at the moment.

Right-click the necessary node on the Call Tree tab and select one of the following options to open the results in a dedicated tab:

  • Focus On Subtree: show only the selected method call. Parent method sample counter shows only the time spent in the selected subtree.

  • Focus On Call: show the selected method and the methods that call it. When this option is enabled, every frame shows only the time spent in the selected method.

  • Exclude Subtree: ignore the selected method call.

  • Exclude Call: ignore all calls to the selected method.

Method List

The Method List collects all methods in the profile data and sorts them by cumulative sample time. Every item in this list has several views:

  • Back Traces shows the hierarchy of callers. Use this view to trace which methods call the selected method.

  • Merged Callees is the call tree summarizing the methods down the call hierarchy.

  • Callee List is the method list summarizing the methods down the call hierarchy.

method list tab in the profiler results

Timeline

The timeline provides the ability to monitor the activity of individual threads. It visualizes CPU activity and memory allocation over time, which is useful for a range of tasks, such as finding out the most active threads, investigating concurrency issues, and profiling I/O.

Timeline in the Profiler tool window
  • Red vertical bars indicate thread sleeping state

  • Green vertical bars indicate thread running state

  • Blue vertical bars indicate memory allocation events

  • The chart at the top shows CPU load

Filter events on the timeline

  • Open the Filter menu in the top-right corner of the tool window and select the types of events that have to be visible.

Get the stacktrace for an event

  • Click an event on the timeline. The stack trace appears on the right-hand side of the Profiler tool window.

    A panel opens showing the stack trace for the selected instant

    To navigate to the method declaration, click the corresponding stack frame. To copy the stack, right-click it and select Copy Stack.

Last modified: 28 June 2024