官术网_书友最值得收藏!

Replacing collections with new instances

The simplest way to empty a collection is to replace it with a new instance, as shown here:

const empty = (collection) => {
if (collection instanceof List) {
return List();
}
if (collection instanceof Map) {
return Map();
}
return null;
};

const myList = List.of(1, 2);
const myMap = Map.of('one', 1, 'two', 2);

const myEmptyList = empty(myList);
const myEmptyMap = empty(myMap);

console.log('myList', myList.toJS());
// -> myList [ 1, 2 ]
console.log('myEmptyList', myEmptyList.toJS());
// -> myEmptyList []
console.log('myMap', myMap.toJS());
// -> myMap { one: 1, two: 2 }
console.log('myEmptyMap', myEmptyMap.toJS());
// -> myEmptyMap {}

We've created a little helper function called empty(). The idea is that it accepts either a list or map as its argument. Depending on the type of collection, a new instance is returned. Then, we can assign this new value to myEmptyList. Remember, as long as myList is referenced, it will never be garbage-collected. If you don't want this to happen, you could store the collection in a variable instead of in a constant. Then, empty() can simply replace the old collection:

var myList = List.of(1, 2);
myList = empty(myList);

Now, the garbage collector can pick up the first collection with the values 1 and 2.

主站蜘蛛池模板: 瑞金市| 高台县| 河曲县| 璧山县| 宜兴市| 腾冲县| 朔州市| 桦川县| 江山市| 扶绥县| 砚山县| 民乐县| 前郭尔| 容城县| 海城市| 高平市| 浮梁县| 泰和县| 娱乐| 西乌| 车险| 桓仁| 白玉县| 长岛县| 金溪县| 林口县| 金昌市| 荆州市| 垣曲县| 蓬溪县| 廉江市| 徐汇区| 贞丰县| 澄江县| 成武县| 化隆| 定陶县| 镇坪县| 义乌市| 崇信县| 吉安市|