Difference between revisions of "Core.enableAllocationTracking"
From GiderosMobile
(Created page with "'''Available since:''' Gideros 2023.1<br/> '''Class:''' Core<br/> === Description === Enables profiling objects allocation. <source lang="lua"> Core.enableAllocationTrack...") |
m (Text replacement - "</source>" to "</syntaxhighlight>") |
||
(2 intermediate revisions by 2 users not shown) | |||
Line 1: | Line 1: | ||
+ | __NOTOC__ | ||
'''Available since:''' Gideros 2023.1<br/> | '''Available since:''' Gideros 2023.1<br/> | ||
'''Class:''' [[Core]]<br/> | '''Class:''' [[Core]]<br/> | ||
=== Description === | === Description === | ||
− | Enables | + | Enables objects allocation profiler. |
− | < | + | <syntaxhighlight lang="lua"> |
− | Core.enableAllocationTracking() | + | (table) = Core.enableAllocationTracking(b) |
− | </ | + | </syntaxhighlight> |
+ | |||
+ | === Parameters === | ||
+ | '''b''': (boolean) true to start the profiler, false to stop the profiler and create the table<br/> | ||
+ | |||
+ | === Return values === | ||
+ | '''Returns''' (table) table with data<br/> | ||
+ | |||
+ | === Example === | ||
+ | <syntaxhighlight lang="lua"> | ||
+ | -- start the profiler | ||
+ | Core.enableAllocationTracking(true) | ||
+ | |||
+ | -- do stuff... | ||
+ | |||
+ | -- end the profiler and create table | ||
+ | local t=Core.enableAllocationTracking(false) | ||
+ | if t then | ||
+ | local counts={} | ||
+ | for k,v in pairs(t) do counts[v]=(counts[v] or 0)+1 end | ||
+ | local sort={} | ||
+ | for k,_ in pairs(counts) do table.insert(sort,k) end | ||
+ | table.sort(sort,function(a,b) return counts[a]>counts[b] end) | ||
+ | for _,k in ipairs(sort) do print(counts[k],k) end | ||
+ | end | ||
+ | </syntaxhighlight> | ||
{{Core}} | {{Core}} |
Latest revision as of 14:27, 13 July 2023
Available since: Gideros 2023.1
Class: Core
Description
Enables objects allocation profiler.
(table) = Core.enableAllocationTracking(b)
Parameters
b: (boolean) true to start the profiler, false to stop the profiler and create the table
Return values
Returns (table) table with data
Example
-- start the profiler
Core.enableAllocationTracking(true)
-- do stuff...
-- end the profiler and create table
local t=Core.enableAllocationTracking(false)
if t then
local counts={}
for k,v in pairs(t) do counts[v]=(counts[v] or 0)+1 end
local sort={}
for k,_ in pairs(counts) do table.insert(sort,k) end
table.sort(sort,function(a,b) return counts[a]>counts[b] end)
for _,k in ipairs(sort) do print(counts[k],k) end
end