Что такое слабые карты ECMAScript 6?

Прочитав это описание: http://wiki.ecmascript.org/doku.php?id=harmony:weak_maps

Я пытаюсь овладеть этим, но я не понимаю общую картину. О чем это все? Похоже, что поддерживается в Firefox 6: http://kangax.github.com/es5-compat-table/non-standard/

3 ответа

Решение

WeakMap

Слабые карты в основном позволяют вам иметь HashTable с ключом, который не является строкой.

Таким образом, вы можете установить ключ, т.е. [1] а потом могу сказать Map.get([1])

Пример из MDN:

var wm1 = new WeakMap(),
    wm2 = new WeakMap();
var o1 = {},
    o2 = function(){},
    o3 = window;

wm1.set(o1, 37);
wm1.set(o2, "azerty");
wm2.set(o1, o2); // a value can be anything, including an object or a function
wm2.set(o3, undefined);
wm2.set(wm1, wm2); // keys and values can be any objects. Even WeakMaps!

wm1.get(o2); // "azerty"
wm2.get(o2); // undefined, because there is no value for o2 on wm2
wm2.get(o3); // undefined, because that is the set value

wm1.has(o2); // true
wm2.has(o2); // false
wm2.has(o3); // true (even if the value itself is 'undefined')

wm1.has(o1);   // true
wm1.delete(o1);
wm1.has(o1);   // false

Причина его существования:

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

Видимо, эмуляция слабых карт вызывает утечки памяти. Я не знаю деталей этих утечек памяти.

Слабая ссылка - это специальный объект, содержащий указатель на объект, но не поддерживающий этот объект.

В Weak Maps реализовано одно приложение со слабыми ссылками:

"Опытный программист на JavaScript заметит, что этот API может быть реализован на JavaScript с двумя массивами (один для ключей, один для значений), совместно используемыми 4 методами API. Такая реализация будет иметь два основных неудобства. Первый - это поиск O(n) (n - это количество ключей на карте). Второй - проблема утечки памяти. С картами, написанными вручную, массив ключей будет хранить ссылки на ключевые объекты, предотвращая их сборку мусора. В собственных WeakMaps ссылки на ключевые объекты хранятся "слабо", что означает, что они не предотвращают сборку мусора в случае, если не будет другой ссылки на объект ". Источник

(Смотрите также мой пост, когда ECMAScript Harmony был впервые выпущен с Firefox...)

WeakMap позволяет использовать объекты в качестве ключей. У него нет никакого способа узнать длину карты. Длина всегда 1. Ключ не может быть примитивным значением

Следует предостеречь об использовании объекта в качестве ключа, так как все объекты по умолчанию являются одиночными в JavaScript, мы должны создать ссылку на объект и использовать ее.

Это потому, что когда мы создаем анонимные объекты, они разные.

if ( {} !== {} ) { console.log('Objects are singletons') };
// will print "Objects are singletons" 

Таким образом, в следующем сценарии мы не можем ожидать получить значение

var wm = new WeakMap()
wm.set([1],'testVal');
wm.get([1]);  // will be undefined

И следующий фрагмент будет работать как положено.

var a = [1];
wm.set(a, 'testVal');
wm.get(a); // will return 'testVal'   
Другие вопросы по тегам