Я использую этот простой HTML-файл, чтобы воспроизвести утечку памяти, я нашел:Углеродные утечки памяти?
<!doctype html>
<html>
<head>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.6/angular.min.js"></script>
<script>
var app = angular.module('testApp', []);
app.directive('directive1', function() {
return {
template: '<div directive2></div>',
scope: true
};
});
app.directive('directive2', function() {
function LeakObject() {}
function Foo() {
this.bar = function($scope) {
$scope.nottheredude;
};
}
return {
scope: true,
link: function($scope) {
$scope.memoryThatLeaks = new LeakObject();
new Foo().bar({});
new Foo().bar($scope);
}
};
});
</script>
</head>
<body ng-app="testApp">
<button ng-click="show = !show">Toggle</button>
<div ng-if="show">The directive <div directive1></div></div>
<div ng-if="!show">Nothing</div>
</body>
</html>
У меня есть директива, что только создает новую область и имеет другую директиву в своем шаблоне.
Другая директива делает что-то немного странное (я попытался сузить проблему до того, что вызывает утечку, и это самый короткий код, который я нашел, что воспроизводит проблему).
В моем основном html, я просто переключаю между ничего и directive1
с простым ng-if
.
Обратите внимание, что directive2
также создает новый объект на $scope
под названием LeakObject
. Я ожидаю, что этот объект будет собран из мусора, когда я перейду к div без ничего, так как область действия директивы должна умереть и все данные на ней с ней, но в соответствии с инструментом моментального снимка кучи Chrome в режиме инкогнито, он не получает нераспределенной.
Я пытаюсь понять, почему это происходит, и почему, если я прокомментирую заявление в методе bar
, это не произойдет.
Шаги для воспроизведения:
- Открыть this file инкогнито
- Open Dev инструменты и перейти к профилям
- Обновить страницу
- Нажмите кнопку
Toggle
дважды (так что теперь вы снова видитеNothing
на экране) - Сделайте снимок кучи
- Напишите «утечку» в фильтре, u может видеть, что
LeakObject
все еще существует, когда он не должен действительно существовать.
Вот как это должно выглядеть следующим образом:
Может кто-то пожалуйста, помогите/объяснить?
Видимо, это не является проблемой в Windows 8, Chrome 42 – Trevor
Не удается воспроизвести проблему на Ubuntu15/темэ – Bolza