14.12.2011, 00:55
|
Интересующийся
|
|
Регистрация: 27.07.2011
Сообщений: 27
|
|
Освобождение памяти или как удалить this?
В общем, javascript-приложение, работа с большими объемами данными, продолжительное время без перезагрузки страницы. Памяти кушает неплохо и со временем работы начинает расходовать все больше. Почитал про освобождение памяти сборщиком мусора, вроде бы почистил все лишние ссылки, но функционал большой, может быть что-то и упустил.
Есть еще подозрения на события. Я так и не понял, удаляются ли они при удалении элемента из DOM. Для назначения событий использую jQuery, live только в нескольких местах и этот обработчик я удаляю вручную.
Усложняет тестирование еще тот факт, что я не знаю как проверить какой объект удалился автоматически, а какой нет. console.dir() - не разу не показал пустой объект, я так понял, что если на объект ссылается консоль, то он, тоже, не удаляется.
В идеале, конечно, вручную удалить this, но я так понял, что это не тривиальная задача.
Подскажите как быть?
|
|
14.12.2011, 01:27
|
|
Модератор
|
|
Регистрация: 27.04.2010
Сообщений: 3,417
|
|
Сообщение от Greck
|
Есть еще подозрения на события. Я так и не понял, удаляются ли они при удалении элемента из DOM. Для назначения событий использую jQuery, live только в нескольких местах и этот обработчик я удаляю вручную.
|
Если ссылок на элемент не остаётся - то удаляются.
Сообщение от Greck
|
Усложняет тестирование еще тот факт, что я не знаю как проверить какой объект удалился автоматически, а какой нет. console.dir() - не разу не показал пустой объект, я так понял, что если на объект ссылается консоль, то он, тоже, не удаляется.
|
Объект живёт, пока на него остаётся хоть одна ссылка.
Сообщение от Greck
|
В идеале, конечно, вручную удалить this, но я так понял, что это не тривиальная задача.
|
А я вообще не понял, что это. Удалить this - это как?
Сообщение от Greck
|
Подскажите как быть?
|
Читать про замыкания и думать, не остаётся ли что-нибудь в них.
|
|
14.12.2011, 02:35
|
Интересующийся
|
|
Регистрация: 27.07.2011
Сообщений: 27
|
|
Цитата:
|
Если ссылок на элемент не остаётся - то удаляются.
|
Знаю, что есть такая проблема, писал с учетом этого. Значит с событиями должно быть все нормально.
Цитата:
|
Объект живёт, пока на него остаётся хоть одна ссылка.
|
Я как бы догадывался А как определить, что на объект нет не одной ссылки и он удалился. console.dir() это должен показать, в каком браузере он точно работает так?
Цитата:
|
А я вообще не понял, что это. Удалить this - это как?
|
Наверное, что-то типа:
var object = {
...
close: function(){
...
delete this;
}
});
Цитата:
|
Читать про замыкания и думать, не остаётся ли что-нибудь в них.
|
Да, объекты создаются конструктором. Но большинство ссылок именно из событий, которые создаются самим объектом и связаны с DOM-элементами, которые затем удаляются.
|
|
14.12.2011, 02:42
|
|
Модератор
|
|
Регистрация: 27.04.2010
Сообщений: 3,417
|
|
console.dir() - ссылка на объект. Пока есть вероятность, что объект может быть использован какой-то ф-цией или ещё чем-либо - объект живёт.
Удалить this нельзя. Не путайте js с c++.
P. S. Не путайте - не в смысле, что в с++ можно удалить this (там и слова-то такого нет), просто delete вообще по-другому действует в js.
|
|
14.12.2011, 02:54
|
Интересующийся
|
|
Регистрация: 27.07.2011
Сообщений: 27
|
|
Цитата:
|
console.dir() - ссылка на объект. Пока есть вероятность, что объект может быть использован какой-то ф-цией или ещё чем-либо - объект живёт.
|
То есть, нет никакой возможности определить удалился ли ненужный объект из памяти или нет?
|
|
14.12.2011, 02:54
|
|
Профессор
|
|
Регистрация: 06.05.2009
Сообщений: 1,163
|
|
Цитата:
|
10.2.1 Глобальный код
Создаётся иерархия областей видимости, которая после инициализации содержит только один глобальный объект и никаких более.
Инстанциация переменных производится при помощи глобального объекта в качестве объекта переменных, с использованием атрибутов свойств { DontDelete }.
Значением this является глобальный объект .
|
http://javascript.ru/ecma/part10#a-10.1.7
__________________
Нужно равняться на лучших, а не оправдываться за счёт худших.
|
|
14.12.2011, 02:58
|
|
Профессор
|
|
Регистрация: 06.05.2009
Сообщений: 1,163
|
|
Greck,
Нет, ну когда вы его явно удалили то есть конечно:
window.object = {};
delete window.object;
alert(window.object);
А вот проверить удалён ли он сборщиком мусора.. В Chrome вроде как есть профайлер памяти и замыканий, если не ошибаюсь. Но это не означает, что во всех браузерах сборщик сработает точно так же. Хотя вероятность этого высока.
__________________
Нужно равняться на лучших, а не оправдываться за счёт худших.
|
|
14.12.2011, 03:25
|
что-то знаю
|
|
Регистрация: 24.05.2009
Сообщений: 5,176
|
|
garbage collector ( тоесть сборщик мусора ) срабатывает по разным правилам, как правило данный метод реализовывают разработчики браузеров. Он не срабатывает сразу же после удаления объекта, а срабатывает в промежутках определенного времени. Тоесть с неким интервалом. Например в ИЕ если удалить объект посредством delete obj; сборщик может не освободить память, понятия не имею как он у них работает, но для ИЕ часто нужно делать явную потерю ссылки тоесть:
var obj = {}
window.obj = null;
Назначая переменной значение null, в реестре замыканий происходит отчисление числа количества принятых ссылок. Когда число ссылок равно нулю, сборщик уничтожает объект.
К сожалению функция delete не гарантирует отчисление от счетчика замыканий, поэтому лучше использовать именно null;
|
|
14.12.2011, 03:25
|
Интересующийся
|
|
Регистрация: 27.07.2011
Сообщений: 27
|
|
Цитата:
|
В Chrome вроде как есть профайлер памяти и замыканий, если не ошибаюсь.
|
Для отладки, это то, что нужно. Думаю, 99% утечек будут общие для всех браузеров.
|
|
14.12.2011, 03:28
|
Интересующийся
|
|
Регистрация: 27.07.2011
Сообщений: 27
|
|
Всем спасибо, вроде бы понял куда дальше копать, попробую отладить сначала все в Хроме, потом посмотрю что с другими браузерами выйдет.
|
|
|
|