Javascript-форум (https://javascript.ru/forum/)
-   Общие вопросы Javascript (https://javascript.ru/forum/misc/)
-   -   Освобождение памяти или как удалить this? (https://javascript.ru/forum/misc/23983-osvobozhdenie-pamyati-ili-kak-udalit.html)

Greck 14.12.2011 00:55

Освобождение памяти или как удалить this?
 
В общем, javascript-приложение, работа с большими объемами данными, продолжительное время без перезагрузки страницы. Памяти кушает неплохо и со временем работы начинает расходовать все больше. Почитал про освобождение памяти сборщиком мусора, вроде бы почистил все лишние ссылки, но функционал большой, может быть что-то и упустил.

Есть еще подозрения на события. Я так и не понял, удаляются ли они при удалении элемента из DOM. Для назначения событий использую jQuery, live только в нескольких местах и этот обработчик я удаляю вручную.

Усложняет тестирование еще тот факт, что я не знаю как проверить какой объект удалился автоматически, а какой нет. console.dir() - не разу не показал пустой объект, я так понял, что если на объект ссылается консоль, то он, тоже, не удаляется.

В идеале, конечно, вручную удалить this, но я так понял, что это не тривиальная задача.

Подскажите как быть?

trikadin 14.12.2011 01:27

Цитата:

Сообщение от Greck
Есть еще подозрения на события. Я так и не понял, удаляются ли они при удалении элемента из DOM. Для назначения событий использую jQuery, live только в нескольких местах и этот обработчик я удаляю вручную.

Если ссылок на элемент не остаётся - то удаляются.

Цитата:

Сообщение от Greck
Усложняет тестирование еще тот факт, что я не знаю как проверить какой объект удалился автоматически, а какой нет. console.dir() - не разу не показал пустой объект, я так понял, что если на объект ссылается консоль, то он, тоже, не удаляется.

Объект живёт, пока на него остаётся хоть одна ссылка.

Цитата:

Сообщение от Greck
В идеале, конечно, вручную удалить this, но я так понял, что это не тривиальная задача.

А я вообще не понял, что это. Удалить this - это как?

Цитата:

Сообщение от Greck
Подскажите как быть?

Читать про замыкания и думать, не остаётся ли что-нибудь в них.

Greck 14.12.2011 02:35

Цитата:

Если ссылок на элемент не остаётся - то удаляются.
Знаю, что есть такая проблема, писал с учетом этого. Значит с событиями должно быть все нормально.

Цитата:

Объект живёт, пока на него остаётся хоть одна ссылка.
Я как бы догадывался :) А как определить, что на объект нет не одной ссылки и он удалился. console.dir() это должен показать, в каком браузере он точно работает так?

Цитата:

А я вообще не понял, что это. Удалить this - это как?
Наверное, что-то типа:
var object = {
    ...
    close: function(){
        ...
        delete this;
    }
});


Цитата:

Читать про замыкания и думать, не остаётся ли что-нибудь в них.
Да, объекты создаются конструктором. Но большинство ссылок именно из событий, которые создаются самим объектом и связаны с DOM-элементами, которые затем удаляются.

trikadin 14.12.2011 02:42

console.dir() - ссылка на объект. Пока есть вероятность, что объект может быть использован какой-то ф-цией или ещё чем-либо - объект живёт.

Удалить this нельзя. Не путайте js с c++.

P. S. Не путайте - не в смысле, что в с++ можно удалить this (там и слова-то такого нет), просто delete вообще по-другому действует в js.

Greck 14.12.2011 02:54

Цитата:

console.dir() - ссылка на объект. Пока есть вероятность, что объект может быть использован какой-то ф-цией или ещё чем-либо - объект живёт.
То есть, нет никакой возможности определить удалился ли ненужный объект из памяти или нет?

Nekromancer 14.12.2011 02:54

Цитата:

10.2.1 Глобальный код

Создаётся иерархия областей видимости, которая после инициализации содержит только один глобальный объект и никаких более.
Инстанциация переменных производится при помощи глобального объекта в качестве объекта переменных, с использованием атрибутов свойств { DontDelete }.
Значением this является глобальный объект .
http://javascript.ru/ecma/part10#a-10.1.7

Nekromancer 14.12.2011 02:58

Greck,
Нет, ну когда вы его явно удалили то есть конечно:
window.object = {};
delete window.object;
alert(window.object);
А вот проверить удалён ли он сборщиком мусора.. В Chrome вроде как есть профайлер памяти и замыканий, если не ошибаюсь. Но это не означает, что во всех браузерах сборщик сработает точно так же. Хотя вероятность этого высока.

devote 14.12.2011 03:25

garbage collector ( тоесть сборщик мусора ) срабатывает по разным правилам, как правило данный метод реализовывают разработчики браузеров. Он не срабатывает сразу же после удаления объекта, а срабатывает в промежутках определенного времени. Тоесть с неким интервалом. Например в ИЕ если удалить объект посредством delete obj; сборщик может не освободить память, понятия не имею как он у них работает, но для ИЕ часто нужно делать явную потерю ссылки тоесть:
var obj = {}
window.obj = null;
Назначая переменной значение null, в реестре замыканий происходит отчисление числа количества принятых ссылок. Когда число ссылок равно нулю, сборщик уничтожает объект.

К сожалению функция delete не гарантирует отчисление от счетчика замыканий, поэтому лучше использовать именно null;

Greck 14.12.2011 03:25

Цитата:

В Chrome вроде как есть профайлер памяти и замыканий, если не ошибаюсь.
Для отладки, это то, что нужно. Думаю, 99% утечек будут общие для всех браузеров.

Greck 14.12.2011 03:28

Всем спасибо, вроде бы понял куда дальше копать, попробую отладить сначала все в Хроме, потом посмотрю что с другими браузерами выйдет.


Часовой пояс GMT +3, время: 23:32.