Basic operations

Taking a heap snapshot

To take a snapshot of the heap, click the “Take snapshot” button, or the camera icon on the left:

../../../_images/memory-1-small.png

The snapshot will occupy the large pane on the right-hand side. On the left, you’ll see an entry for the new snapshot, including its timestamp, size, and controls to save or clear this snapshot:

../../../_images/memory-2-small.png

Clearing a snapshot

To remove a snapshot, click the “X” icon:

../../../_images/memory-3-small.png

Saving and loading snapshots

If you close the Memory tool, all unsaved snapshots will be discarded. To save a snapshot click “Save”:

../../../_images/memory-4-small.png

You’ll be prompted for a name and location, and the file will be saved with an .fxsnapshot extension.

To load a snapshot from an existing .fxsnapshot file, click the import button, which looks like a rectangle with an arrow rising from it:

../../../_images/memory-5-small.png

You’ll be prompted to find a snapshot file on disk.

Comparing snapshots

You can diff two heap snapshots. The diff shows you where memory was allocated or freed between the two snapshots.

To create a diff, click the button that looks like a Venn diagram next to the camera icon:

../../../_images/memory-6-small.png

You’ll be prompted to select the snapshot to use as a baseline, then the snapshot to compare. The tool then shows you the differences between the two snapshots:



Note

When you’re looking at a comparison, you can’t use the Dominators view or the Tree Map view.

Recording call stacks

The Memory tool can tell you exactly where in your code you are allocating memory. However, recording this information has a run-time cost, so you must ask the tool to record memory calls before the memory is allocated, if you want to see memory call sites in the snapshot. To do this, check “Record call stacks”:

../../../_images/memory-7-small.png