Espruino:Справочник по API/Класс E/getSizeOf(): различия между версиями
Нет описания правки |
Нет описания правки |
||
Строка 52: | Строка 52: | ||
=См.также= | =См.также= | ||
=Внешние ссылки= | =Внешние ссылки= | ||
Строка 58: | Строка 58: | ||
<references /> | <references /> | ||
{{Навигационная таблица/Espruino | {{Навигационная таблица/Портал/Espruino}} | ||
Версия от 15:14, 20 мая 2023
Функция E.getSizeOf()[1]
Синтаксис
E.getSizeOf(v, depth)
Параметры
- v – переменная, размер которой надо узнать
- depth – уровень подробности результата. Если задать depth<=0 или undefined, то будет возвращено одно целое число
Возвращаемое значение
Информацию о размере переменной (см. ниже).
Описание
Возвращает количество блоков, используемых заданной переменной. Эта функция может пригодиться в случае, когда у вас не хватает памяти, и вы хотите посмотреть, что занимает большую часть доступной памяти.
Если задать в аргументе depth значение выше нуля, а в v – многосоставную переменную (т.е. переменную, внутри которой что-то есть), функция вернет массив, содержащий названия всех свойств (включая названия внутренних объектов Espruino) и их размеры. Если задать depth>1, в результате также будет поле more, содержащее информацию о дочерних объектах внутри дочерних объектов.
К примеру, E.getSizeOf(function(a,b) { }) вернет «5».
Но E.getSizeOf(function(a,b) { }, 1) вернет:
[
{
"name": "a",
"size": 1 },
{
"name": "b",
"size": 1 },
{
"name": "\xFFcod",
"size": 2 }
]
В это случае число «2» в аргументе depth не даст никакого результата, т.к. в переменной больше нет дочерних объектов, которые можно было бы показать.
Более подробно читайте тут.
Примечание: Эта функция не доступна для устройств с маленькой flash-памятью.
См.также
Внешние ссылки