Methods

Chrome DevTools

HeapProfiler.addInspectedHeapObject #

Enables console to refer to the node with given id via $x (see Command Line API for more details $x functions).

Parameters

heapObjectId
HeapSnapshotObjectId

Heap snapshot object id to be accessible by means of $x command line API.


HermesHermes (Legacy)Chrome DevTools

HeapProfiler.collectGarbage #


Chrome DevTools

HeapProfiler.disable #


Chrome DevTools

HeapProfiler.enable #


HermesHermes (Legacy)Chrome DevTools

HeapProfiler.getHeapObjectId #

Parameters

objectId
Runtime.RemoteObjectId

Identifier of the object to get heap object id for.

Return object

heapSnapshotObjectId
HeapSnapshotObjectId

Id of the heap snapshot object corresponding to the passed remote object id.


HermesHermes (Legacy)Chrome DevTools

HeapProfiler.getObjectByHeapObjectId #

Parameters

objectGroup
Optional
string

Symbolic group name that can be used to release multiple objects.

Return object

result
Runtime.RemoteObject

Evaluation result.


Chrome DevTools

HeapProfiler.getSamplingProfile #

Return object

profile
SamplingHeapProfile

Return the sampling profile being collected.


HermesHermes (Legacy)Chrome DevTools

HeapProfiler.startSampling #

Parameters

samplingInterval
Optional
number

Average sample interval in bytes. Poisson distribution is used for the intervals. The default value is 32768 bytes.

includeObjectsCollectedByMajorGC
Optional
boolean

By default, the sampling heap profiler reports only objects which are still alive when the profile is returned via getSamplingProfile or stopSampling, which is useful for determining what functions contribute the most to steady-state memory usage. This flag instructs the sampling heap profiler to also include information about objects discarded by major GC, which will show which functions cause large temporary memory usage or long GC pauses.

includeObjectsCollectedByMinorGC
Optional
boolean

By default, the sampling heap profiler reports only objects which are still alive when the profile is returned via getSamplingProfile or stopSampling, which is useful for determining what functions contribute the most to steady-state memory usage. This flag instructs the sampling heap profiler to also include information about objects discarded by minor GC, which is useful when tuning a latency-sensitive application for minimal GC activity.


HermesHermes (Legacy)Chrome DevTools

HeapProfiler.startTrackingHeapObjects #

Parameters

trackAllocations
Optional
boolean

HermesHermes (Legacy)Chrome DevTools

HeapProfiler.stopSampling #

Return object

profile
SamplingHeapProfile

Recorded sampling heap profile.


HermesHermes (Legacy)Chrome DevTools

HeapProfiler.stopTrackingHeapObjects #

Parameters

reportProgress
Optional
boolean

If true 'reportHeapSnapshotProgress' events will be generated while snapshot is being taken when the tracking is stopped.

treatGlobalObjectsAsRoots
Optional
boolean

Deprecated in favor of exposeInternals.

Deprecated
captureNumericValue
Optional
boolean

If true, numerical values are included in the snapshot

exposeInternals
Optional
boolean

If true, exposes internals of the snapshot.

Experimental

HermesHermes (Legacy)Chrome DevTools

HeapProfiler.takeHeapSnapshot #

Parameters

reportProgress
Optional
boolean

If true 'reportHeapSnapshotProgress' events will be generated while snapshot is being taken.

treatGlobalObjectsAsRoots
Optional
boolean

If true, a raw snapshot without artificial roots will be generated. Deprecated in favor of exposeInternals.

Deprecated
captureNumericValue
Optional
boolean

If true, numerical values are included in the snapshot

exposeInternals
Optional
boolean

If true, exposes internals of the snapshot.

Experimental

Events

HermesHermes (Legacy)Chrome DevTools

HeapProfiler.addHeapSnapshotChunk #

Parameters

chunk
string

HermesHermes (Legacy)Chrome DevTools

HeapProfiler.heapStatsUpdate #

If heap objects tracking has been started then backend may send update for one or more fragments

Parameters

statsUpdate
array[ integer ]

An array of triplets. Each triplet describes a fragment. The first integer is the fragment index, the second integer is a total count of objects for the fragment, the third integer is a total size of the objects for the fragment.


HermesHermes (Legacy)Chrome DevTools

HeapProfiler.lastSeenObjectId #

If heap objects tracking has been started then backend regularly sends a current value for last seen object id and corresponding timestamp. If the were changes in the heap since last event then one or more heapStatsUpdate events will be sent before a new lastSeenObjectId event.

Parameters

lastSeenObjectId
integer
timestamp
number

HermesHermes (Legacy)Chrome DevTools

HeapProfiler.reportHeapSnapshotProgress #

Parameters

done
integer
total
integer
finished
Optional
boolean

Chrome DevTools

HeapProfiler.resetProfiles #

Types

HermesHermes (Legacy)Chrome DevTools

HeapProfiler.HeapSnapshotObjectId #

Heap snapshot object id.

Type: string


HermesHermes (Legacy)Chrome DevTools

HeapProfiler.SamplingHeapProfile #

Sampling profile.

Type: object

Properties

samples

HermesHermes (Legacy)Chrome DevTools

HeapProfiler.SamplingHeapProfileNode #

Sampling Heap Profile node. Holds callsite information, allocation statistics and child nodes.

Type: object

Properties

callFrame
Runtime.CallFrame

Function location.

selfSize
number

Allocations size in bytes for the node excluding children.

id
integer

Node id. Ids are unique across all profiles collected between startSampling and stopSampling.

children
array[ SamplingHeapProfileNode ]

Child nodes.


HermesHermes (Legacy)Chrome DevTools

HeapProfiler.SamplingHeapProfileSample #

A single sample from a sampling profile.

Type: object

Properties

size
number

Allocation size in bytes attributed to the sample.

nodeId
integer

Id of the corresponding profile tree node.

ordinal
number

Time-ordered sample ordinal number. It is unique across all profiles retrieved between startSampling and stopSampling.