01. Set
๐นSet ๊ฐ์ฒด๋ ์ค๋ณต๋์ง ์๋ ์ ์ผํ ๊ฐ๋ค์ ์งํฉ์ด๋ค.
๐น ๋ฐฐ์ด๊ณผ ์ ์ฌํ์ง๋ง ๋ค์๊ณผ ๊ฐ์ ์ฐจ์ด๊ฐ ์๋ค.
๊ตฌ๋ถ | ๋ฐฐ์ด | Set ๊ฐ์ฒด |
๋์ผํ ๊ฐ์ ์ค๋ณตํ์ฌ ํฌํจํ ์ ์๋ค. | O | X |
์์ ์์์ ์๋ฏธ๊ฐ ์๋ค. | O | X |
์ธ๋ฑ์ค๋ก ์์์ ์ ๊ทผํ ์ ์๋ค. | O | X |
โก๏ธ ์ํ์ ์งํฉ์ ํน์ฑ๊ณผ ์ผ์นํ๋ค.
โก๏ธ Set์ ์ํ์ ์งํฉ์ ๊ตฌํํ๊ธฐ ์ํ ์๋ฃ๊ตฌ์กฐ๋ค. (๊ต์งํฉ, ํฉ์งํฉ, ์ฐจ์งํฉ, ์ฌ์งํฉ ๊ตฌํ ๊ฐ๋ฅ)
1. Set ๊ฐ์ฒด์ ์์ฑ
๐ก Set ๊ฐ์ฒด๋ Set ์์ฑ์ ํจ์๋ก ์์ฑํ๋ค.
๐น Set ์์ฑ์ ํจ์์ ์ธ์๋ฅผ ์ ๋ฌํ์ง ์์ผ๋ฉด ๋น Set ๊ฐ์ฒด๊ฐ ์์ฑ๋๋ค.
const set = new Set();
console.log(set); // Set(0) {}
๐ก Set ์์ฑ์ ํจ์๋ ์ดํฐ๋ฌ๋ธ์ ์ธ์๋ก ์ ๋ฌ๋ฐ์ Set ๊ฐ์ฒด๋ฅผ ์์ฑํ๋ค.
๐น Set ๊ฐ์ฒด๋ ์ค๋ณต์ ํ์ฉํ์ง ์์ผ๋ฏ๋ก, ์ดํฐ๋ฌ๋ธ์ ์ค๋ณต๋ ๊ฐ์ Set ๊ฐ์ฒด์ ์์๋ก ์ ๋ฌ๋์ง ์๋๋ค.
const set1 = new Set([1, 2, 3, 3]);
console.log(set1); // Set(3) {1, 2, 3};
const set2 = new Set('hello');
console.log(set2); // Set(4) {"h", "e", "l", "o"}
โ ์ค๋ณต์ ํ์ฉํ์ง ์๋ Set ๊ฐ์ฒด์ ํน์ฑ์ ํ์ฉํ์ฌ ๋ฐฐ์ด์์ ์ค๋ณต๋ ์์๋ฅผ ์ ๊ฑฐํ ์ ์๋ค.
2. ์์ ๊ฐ์ ํ์ธ
๐ก Set.prototype.size ํ๋กํผํฐ๋ฅผ ์ฌ์ฉํ๋ค.
const { size } = new Set([1, 2, 3, 3]);
console.log(size); // 3
3. ์์ ์ถ๊ฐ
๐ก Set.prototype.add ๋ฉ์๋๋ฅผ ์ฌ์ฉํ๋ค.
const set = new Set();
console.log(set); // Set(0) {}
set.add(1);
console.log(set); // Set(1) {1}
๐น add ๋ฉ์๋๋ ์๋ก์ด ์์๊ฐ ์ถ๊ฐ๋ Set ๊ฐ์ฒด๋ฅผ ๋ฐํํ๋ค. -> add ๋ฉ์๋๋ฅผ ์ฐ์์ ์ผ๋ก ํธ์ถ ๊ฐ๋ฅ!
๐น Set ๊ฐ์ฒด์ ์ค๋ณต๋ ์์์ ์ถ๊ฐ๋ ํ์ฉ๋์ง ์๋๋ค. -> ์๋ฌ๊ฐ ๋ฐ์ํ์ง๋ ์๊ณ ๋ฌด์๋๋ค.
โ ์ผ์น ๋น๊ต ์ฐ์ฐ์ === ์ ์ฌ์ฉํ๋ฉด NaN๊ณผ NaN์ ๋ค๋ฅด๋ค๊ณ ํ๊ฐํ๋ค.
โ ํ์ง๋ง Set ๊ฐ์ฒด๋ NaN๊ณผ NaN์ ๊ฐ๋ค๊ณ ํ๊ฐ -> ์ค๋ณต ์ถ๊ฐ ํ์ฉ X
4, ์์ ์กด์ฌ ์ฌ๋ถ ํ์ธ
๐น Set.prototype.has ๋ฉ์๋๋ฅผ ์ฌ์ฉํ๋ค.
๐น has ๋ฉ์๋๋ ํน์ ์์์ ์กด์ฌ ์ฌ๋ถ๋ฅผ ๋ํ๋ด๋ ๋ถ๋ฆฌ์ธ ๊ฐ์ ๋ฐํํ๋ค.
const set = new Set([1, 2, 3]);
console.log(set.has(2)); // true
console.log(set.has(4)); // false
5. ์์ ์ญ์
๐ก Set.prototype.delete ๋ฉ์๋๋ฅผ ์ฌ์ฉํ๋ค.
๐น ์ญ์ ์ฑ๊ณต ์ฌ๋ถ๋ฅผ ๋ํ๋ด๋ ๋ถ๋ฆฌ์ธ ๊ฐ์ ๋ฐํํ๋ค.
๐น ์ธ๋ฑ์ค๊ฐ ์๋๋ผ, ์ญ์ ํ๋ ค๋ ์์๊ฐ์ ์ธ์๋ก ์ ๋ฌํด์ผ ํ๋ค.(Set ๊ฐ์ฒด๋ ์์์ ์๋ฏธ๊ฐ ์๊ธฐ ๋๋ฌธ!)
const set = new Set([1, 2, 3]);
// ์์ 2๋ฅผ ์ญ์ ํ๋ค.
set.delete(2);
console.log(set); // Set(2) {1, 3}
6. ์์ ์ผ๊ด ์ญ์
๐ก Set.prototype.clear ๋ฉ์๋๋ฅผ ์ฌ์ฉํ๋ค.
๐น clear ๋ฉ์๋๋ ์ธ์ ๋ undefined๋ฅผ ๋ฐํํ๋ค.
const set = new Set([1, 2, 3]);
set.clear();
console.log(set); // Set(0) {}
7. ์์ ์ํ
๐ก Set.prototype.forEach ๋ฉ์๋๋ฅผ ์ฌ์ฉํ๋ค.
๐น ์ฝ๋ฐฑ ํจ์์ forEach ๋ฉ์๋์ ์ฝ๋ฐฑ ํจ์ ๋ด๋ถ์์ this๋ก ์ฌ์ฉ๋ ๊ฐ์ฒด(์ต์ )๋ฅผ ์ธ์๋ก ์ ๋ฌํ๋ค.
- ์ฒซ ๋ฒ์งธ ์ธ์ : ํ์ฌ ์ํ ์ค์ธ ์์๊ฐ
- ๋ ๋ฒ์งธ ์ธ์ : ํ์ฌ ์ํ ์ค์ธ ์์๊ฐ
- ์ธ ๋ฒ์งธ ์ธ์ : ํ์ฌ ์ํ ์ค์ธ Set ๊ฐ์ฒด ์์ฒด
โก๏ธ ์ฒซ ๋ฒ์งธ ์ธ์์ ๋ ๋ฒ์งธ ์ธ์๋ ๊ฐ์ ๊ฐ์ด๋ค.
โ Array.prototype.forEach ๋ฉ์๋์ ์ธํฐํ์ด์ค๋ฅผ ํต์ผํ๊ธฐ ์ํจ!
(Array.prototype.forEach ๋ฉ์๋์ ์ฝ๋ฐฑ ํจ์๋ ๋ ๋ฒ์งธ ์ธ์๋ก ํ์ฌ ์ํ ์ค์ธ ์์์ '์ธ๋ฑ์ค' ๋ฅผ ์ ๋ฌ๋ฐ์ง๋ง, Set ๊ฐ์ฒด๋ ์์์ ์๋ฏธ ์์ด์ ์ธ๋ฑ์ค X)
const set = new Set([1, 2, 3]);
set.forEach((v, v2, set) => console.log(v, v2, set));
/*
1 1 Set(3) {1, 2, 3}
2 2 Set(3) {1, 2, 3}
3 3 Set(3) {1, 2, 3}
*/
๐ก Set ๊ฐ์ฒด๋ ์ดํฐ๋ฌ๋ธ์ด๋ค.
โก๏ธ for...of ๋ฌธ์ผ๋ก ์ํ ๊ฐ๋ฅ / ์คํ๋ ๋ ๋ฌธ๋ฒ, ๋ฐฐ์ด ๋์คํธ๋ญ์ฒ๋ง์ ๋์์ด ๋ ์ ์๋ค.
8. ์งํ ์ฐ์ฐ
๐ก Set ๊ฐ์ฒด๋ ์ํ์ ์งํฉ์ ๊ตฌํํ๊ธฐ ์ํ ์๋ฃ๊ตฌ์กฐ์ด๋ค.
๊ต์งํฉ
๊ต์งํฉ A ∩ B๋ ์งํฉ A์ ์งํฉ B์ ๊ณตํต ์์๋ก ๊ตฌ์ฑ๋๋ค.
Set.prototype.intersection = function (set) {
const result = new Set();
for (const value of set) {
// 2๊ฐ์ set์ ์์๊ฐ ๊ณตํต๋๋ ์์์ด๋ฉด ๊ต์งํฉ์ ๋์์ด๋ค.
if (this.has(value)) result.add(value);
}
return result;
};
const setA = new Set([1, 2, 3, 4]);
const setB = new Set([2, 4]);
// setA์ setB์ ๊ต์งํฉ
console.log(setA.intersection(setB)); // Set(2) {2, 4}
// setB์ setA์ ๊ต์งํฉ
console.log(setB.intersection(setA)); // Set(2) {2, 4}
ํฉ์งํฉ
ํฉ์งํฉ A ∪ B๋ ์งํฉ A์ ์งํฉ B์ ์ค๋ณต ์๋ ๋ชจ๋ ์์๋ก ๊ตฌ์ฑ๋๋ค.
Set.prototype.union = function (set) {
// this(Set ๊ฐ์ฒด)๋ฅผ ๋ณต์ฌ
const result = new Set(this);
for(const value of set) {
// ํฉ์งํฉ์ 2๊ฐ์ Set ๊ฐ์ฒด์ ๋ชจ๋ ์์๋ก ๊ตฌ์ฑ๋ ์งํฉ์ด๋ค. ์ค๋ณต๋ ์์๋ ํฌํจ๋์ง ์๋๋ค.
result.add(value);
};
const setA = new Set([1, 2, 3, 4]);
const setB = new Set([2, 4]);
// setA์ setB์ ํฉ์งํฉ
console.log(setA.union(setB)); // Set(4) {1, 2, 3, 4}
// setB์ setA์ ํฉ์งํฉ
console.log(setB.union(setA)); // Set(4) {2, 4, 1, 3}
์ฐจ์งํฉ
์ฐจ์งํฉ A-B๋ ์งํฉ A์๋ ์กด์ฌํ์ง๋ง ์งํฉ B์๋ ์กด์ฌํ์ง ์๋ ์์๋ก ๊ตฌ์ฑ๋๋ค.
Set.prototype.difference = function (set) {
// this(Set ๊ฐ์ฒด)๋ฅผ ๋ณต์ฌ
const result = new Set(this);
for (const value of set) {
// ์ฐจ์งํฉ์ ์ด๋ ํ์ชฝ ์งํฉ์๋ ์กด์ฌํ์ง๋ง ๋ค๋ฅธ ํ์ชฝ ์งํฉ์๋ ์กด์ฌํ์ง ์๋ ์์๋ก ๊ตฌ์ฑ๋ ์งํฉ์ด๋ค.
result.delete(value);
}
return result;
};
const setA = new Set([1, 2, 3, 4]);
const setB = new Set([2, 4]);
// setA์ ๋ํ setB์ ์ฐจ์งํฉ
console.log(setA.difference(setB)); // Set(2) {1, 3}
// setB์ ๋ํ setA์ ์ฐจ์งํฉ
console.log(setB.difference(setA)); // Set(0) {}
๋ถ๋ถ ์งํฉ๊ณผ ์์ ์งํฉ
์งํฉ A๊ฐ ์งํฉ B์ ํฌํจ๋๋ ๊ฒฝ์ฐ(A ⊆ B) ์งํฉ A๋ ์งํฉ B์ ๋ถ๋ถ ์งํฉ์ด๋ฉฐ, ์งํฉ B๋ ์งํฉ A์ ์์ ์งํฉ์ด๋ค.
// this๊ฐ subset์ ์์ ์งํฉ์ธ์ง ํ์ธํ๋ค.
Set.prototype.isSuperset = function (subset) {
for (const value of subset) {
// superset์ ๋ชจ๋ ์์๊ฐ subset์ ๋ชจ๋ ์์๋ฅผ ํฌํจํ๋์ง ํ์ธ
if (!this.has(value)) return false;
}
return true;
};
const setA = new Set([1, 2, 3, 4]);
const setB = new Set([2, 4]);
// setA๊ฐ setB์ ์์ ์งํฉ์ธ์ง ํ์ธํ๋ค.
console.log(setA.isSuperset(setB)); // true
// setB๊ฐ setA์ ์์ ์งํฉ์ธ์ง ํ์ธํ๋ค.
console.log(setB.isSuperset(setA)); // false
02. Map
๐ก Map ๊ฐ์ฒด๋ ํค์ ๊ฐ์ ์์ผ๋ก ์ด๋ฃจ์ด์ง ์ปฌ๋ ์ ์ด๋ค.
๐น ๊ฐ์ฒด์ ์ ์ฌํ์ง๋ง ๋ค์๊ณผ ๊ฐ์ ์ฐจ์ด๊ฐ ์๋ค.
๊ตฌ๋ถ | ๊ฐ์ฒด | Map ๊ฐ์ฒด |
ํค๋ก ์ฌ์ฉํ ์ ์๋ ๊ฐ | ๋ฌธ์์ด ๋๋ ์ฌ๋ฒ ๊ฐ | ๊ฐ์ฒด๋ฅผ ํฌํจํ ๋ชจ๋ ๊ฐ |
์ดํฐ๋ฌ๋ธ | X | O |
์์ ๊ฐ์ ํ์ธ | Object.keys(obj).length | map.size |
1. Map ๊ฐ์ฒด์ ์์ฑ
๐ก Map ๊ฐ์ฒด๋ Map ์์ฑ์ ํจ์๋ก ์์ฑํ๋ค.
๐น Map ์์ฑ์ ํจ์์ ์ธ์๋ฅผ ์ ๋ฌํ์ง ์์ผ๋ฉด ๋น Map ๊ฐ์ฒด๊ฐ ์์ฑ๋๋ค.
๐น Map ์์ฑ์ ํจ์๋ ์ดํฐ๋ฌ๋ธ์ ์ธ์๋ก ์ ๋ฌ๋ฐ์ Map ๊ฐ์ฒด๋ฅผ ์์ฑํ๋ค.
๐น ์ด๋ ์ธ์๋ก ์ ๋ฌ๋๋ ์ดํฐ๋ฌ๋ธ์ ํค์ ๊ฐ์ ์์ผ๋ก ์ด๋ฃจ์ด์ง ์์๋ก ๊ตฌ์ฑ๋์ด์ผ ํ๋ค.
๐น Map ์์ฑ์ ํจ์์ ์ธ์๋ก ์ ๋ฌํ ์ดํฐ๋ฌ๋ธ์ ์ค๋ณต๋ ํค๋ฅผ ๊ฐ๋ ์์๊ฐ ์กด์ฌํ๋ฉด -> ๊ฐ์ด ๋ฎ์ด์จ์ง
โก๏ธ ์ค๋ณต๋ ํค๋ฅผ ๊ฐ๋ ์์ ์กด์ฌ X
2. ์์ ๊ฐ์ ํ์ธ
๐ก Map.prototype.size ํ๋กํผํฐ๋ฅผ ์ฌ์ฉํ๋ค.
const { size } = new Map([['key1', 'value1'], ['key2', 'value2']]);
console.log(size); // 2
3. ์์ ์ถ๊ฐ
๐ก Map.prototype.set ๋ฉ์๋๋ฅผ ์ฌ์ฉํ๋ค.
const map = new Map();
console.log(map); // Map(0) {}
map.set('key1', 'value1');
console.log(map); // Map(1) {"key1" => "value1"}
4. ์์ ์ทจ๋
๐ก Map.prototype.get ๋ฉ์๋๋ฅผ ์ฌ์ฉํ๋ค.
๐น get ๋ฉ์๋์ ์ธ์๋ก ํค๋ฅผ ์ ๋ฌํ๋ฉด -> Map ๊ฐ์ฒด์์ ์ธ์๋ก ์ ๋ฌํ ํค๋ฅผ ๊ฐ๋ ๊ฐ์ ๋ฐํํ๋ค.
const map = new Map();
const lee = { name: 'Lee' };
const kim = { name: 'Kim' };
map
.set(lee, 'developer')
.set(kim, 'designer');
console.log(map.get(lee)); // developer
console.log(map.get('key')); // undefined
5. ์์ ์กด์ฌ ์ฌ๋ถ ํ์ธ
๐ก Map ๊ฐ์ฒด์ ํน์ ์์๊ฐ ์กด์ฌํ๋์ง ํ์ธํ๋ ค๋ฉด Map.prototype.has ๋ฉ์๋๋ฅผ ์ฌ์ฉํ๋ค.
๐น has ๋ฉ์๋๋ ํน์ ์์์ ์กด์ฌ ์ฌ๋ถ๋ฅผ ๋ํ๋ด๋ ๋ถ๋ฆฌ์ธ ๊ฐ์ ๋ฐํํ๋ค.
const lee = { name: 'Lee' };
const kim = { name: 'Kim' };
const map = new Map([[lee, 'developer'], [kim, 'designer']]);
console.log(map.has(lee)); // true
console.log(map.has('key')); // false
6. ์์ ์ญ์
๐ก Map ๊ฐ์ฒด์ ์์๋ฅผ ์ญ์ ํ๋ ค๋ฉด Map.prototype.delete ๋ฉ์๋๋ฅผ ์ฌ์ฉํ๋ค.
๐น delete ๋ฉ์๋๋ ์ญ์ ์ฑ๊ณต ์ฌ๋ถ๋ฅผ ๋ํ๋ด๋ ๋ถ๋ฆฌ์ธ ๊ฐ์ ๋ฐํํ๋ค.
const lee = { name: 'Lee' };
const kim = { name: 'Kim' };
const map = new Map([[lee, 'developer'], [kim, 'designer']]);
map.delete(kim);
console.log(map); // Map(1) { {name: "Lee"} => "developer" }
7. ์์ ์ผ๊ด ์ญ์
๐ก Map ๊ฐ์ฒด์ ์์๋ฅผ ์ผ๊ด ์ญ์ ํ๋ ค๋ฉด Map.prototype.clear ๋ฉ์๋๋ฅผ ์ฌ์ฉํ๋ค.
๐น clear ๋ฉ์๋๋ ์ธ์ ๋ undefined๋ฅผ ๋ฐํํ๋ค.
const lee = { name: 'Lee' };
const kim = { name: 'Kim' };
const map = new Map([[lee, 'developer'], [kim, 'designer']]);
map.clear();
console.log(map); // Map(0) {}
8. ์์ ์ํ
๐ก Map ๊ฐ์ฒด์ ์์๋ฅผ ์ํํ๋ ค๋ฉด Map.prototype.forEach ๋ฉ์๋๋ฅผ ์ฌ์ฉํ๋ค.
๐น ์ฝ๋ฐฑ ํจ์๋ 3๊ฐ์ ์ธ์๋ฅผ ์ ๋ฌ๋ฐ๋๋ค.
- ์ฒซ ๋ฒ์งธ ์ธ์ : ํ์ฌ ์ํ ์ค์ธ ์์๊ฐ
- ๋ ๋ฒ์งธ ์ธ์ : ํ์ฌ ์ํ ์ค์ธ ์์ํค
- ์ธ ๋ฒ์งธ ์ธ์ : ํ์ฌ ์ํ ์ค์ธ Map ๊ฐ์ฒด ์์ฒด
const lee = { name: 'Lee' };
const kim = { name: 'Kim' };
const map = new Map([[lee, 'developer'], [kim, 'designer']]);
map.forEach((v, k, map) => console.log(v, k, map));
/*
developer {name: "Lee"} Map(2) {
{name: "Lee"} => "developer",
{name: "Kim"} => "designer"
}
designer {name: "Kim"} Map(2) {
{name: "Lee"} => "developer",
{name: "Kim"} => "designer"
}
*/
โ Map ๊ฐ์ฒด๋ ์ดํฐ๋ฌ๋ธ์ด๋ค.
โก๏ธ for...of ๋ฌธ์ผ๋ก ์ํ ๊ฐ๋ฅ / ์คํ๋ ๋ ๋ฌธ๋ฒ๊ณผ ๋ฐฐ์ด ๋์คํธ๋ญ์ฒ๋ง ํ ๋น์ ๋์์ด ๋ ์ ์๋ค.
๐ ์ฐธ๊ณ ์๋ฃ