Finding Accumulation Points

This page demonstrates how accumulation points can be detected using the Heap Profiler.

Below is the source code of the script, for reference:

function CollectionItem(s)
{
  this.s = s;
}

function Collection()
{
  this.items = [];
}

Collection.prototype = {
  add: function(item)
  {
    this.items.push(item);
  },

  item: function(index)
  {
    return this.items[index];
  }
}

function createCollection(count)
{
  var collection = new Collection();
  for (var i = 0; i < count; ++i)
    collection.add(new CollectionItem(i.toString()));
  return collection;
}

var holder1 = [createCollection(10000), createCollection(15000)];
var holder2 = [holder1[0]];

Using the Dominators view, it's easy to spot collection objects that are small by themselves but retain lots of memory. In the Dominators view, find the DOMWindows node (usually, the topmost one) and expand it. Look at the top two child nodes (by default nodes are sorted by their retained size). The first one is a system wrapper around the holder1 array. The second one is the Collection node. Both of them have small shallow size, but big retained size, due to a fact that they hold lots of CollectionItem objects.

Note that the Dominators reveals dependencies between objects, not their references. For example, one of the Collection objects is shared between two arrays, thus it is not retained by any of them, but by the DOMWindows object.

To see, how an object is actually referenced, click on it, and look at the lower panel that shows retaining paths.