ES6 Map 또는 Set 객체를 어떻게 얕게 복제 합니까?
동일한 키와 값을 가진 새 맵 또는 세트를 얻고 싶습니다.
답변:
생성자를 사용하여 맵 및 세트 복제 :
var clonedMap = new Map(originalMap)
var clonedSet = new Set(originalSet)
for 루프를 통해 새 Set을 만드는 것이 Set 생성자보다 빠릅니다. 정도는 낮지 만지도에서도 마찬가지입니다.
const timeInLoop = (desc, loopCount, fn) => {
const d = `${desc}: ${loopCount.toExponential()}`
console.time(d)
for (let i = 0; i < loopCount; i++) {
fn()
}
console.timeEnd(d)
}
const set = new Set([1, 2, 3, 4, 5, 6, 7, 8, 9, 10])
const setFromForLoop = x => {
const y = new Set()
for (const item of x) y.add(item)
return y
}
const map = new Map([['a', 1], ['b', 2], ['c', 3], ['d', 4], ['e', 5]])
const mapFromForLoop = x => {
const y = new Map()
for (const entry of x) y.set(...entry)
return y
}
timeInLoop('new Set(set)', 1e5, () => new Set(set))
timeInLoop('setFromForLoop(set)', 1e5, () => setFromForLoop(set))
timeInLoop('new Map(map)', 1e5, () => new Map(map))
timeInLoop('mapFromForLoop(map)', 1e5, () => mapFromForLoop(map))
Set
(하지 않는 것처럼 Map
).
new Set(set)
Safari에서는 setFromForLoop(set)
약 15-20ms 더 빠르지 만 Chrome에서는 약 20-28ms 더 빠릅니다.