map-set

Map

key์™€ value๋ฅผ ์ด์šฉํ•ด ๋ฐ์ดํ„ฐ๋ฅผ ์ €์žฅํ•˜๋Š” ์ž๋ฃŒ๊ตฌ์กฐ

๊ฐ์ฒด์™€๋Š” ๋‹ค๋ฅด๊ฒŒ key์— ๋‹ค์–‘ํ•œ ์ž๋ฃŒํ˜•์„ ํ—ˆ์šฉํ•œ๋‹ค

map์˜ value์— ์ ‘๊ทผํ• ๋•Œ ๋Œ€๊ด„ํ˜ธ[]๋กœ ์ ‘๊ทผ์ด ๊ฐ€๋Šฅํ•˜๋‚˜ ์ด๋Š” ๊ฐ์ฒด์™€ ๊ฐ™์€ ์ทจ๊ธ‰์„ ํ•˜๊ธฐ์— get,set์„ ์ด์šฉ

key๋กœ ๊ฐ์ฒด๋„ ํ—ˆ์šฉํ•œ๋‹ค.

๋งต์€ key๋ฅผ ๋น„๊ตํ• ๋•Œ ===์ด ์•„๋‹Œ SameValueZero๋ผ๋Š” ์•Œ๊ณ ๋ฆฌ์ฆ˜์œผ๋กœ ๋“ฑ๊ฐ€ ์—ฌ๋ถ€๋ฅผ ํ™•์ธํ•˜๊ธฐ ๋•Œ๋ฌธ์— NaN๋„ key๋กœ ์‚ฌ์šฉ๊ฐ€๋Šฅํ•˜๋‹ค

๋งต์˜ key๋กœ ๊ฐ์ฒด๋ฅผ ์‚ฌ์šฉํ•˜๊ณ  ๊ฐ์ฒด๋ฅผ ์‚ญ์ œ์‹œ์— ๊ฐ€๋น„์ง€ ์ปฌ๋ ‰ํ„ฐ๊ฐ€ ๊ฐ์ฒด๋ฅผ ์‚ญ์ œํ•˜์ง€ ์•Š๋Š”๋‹ค. (์—ฌ์ „ํžˆ ๋งต์ด ๊ฐ์ฒด๋ฅผ ์ฐธ์กฐํ•˜๊ณ  ์žˆ๊ธฐ ๋•Œ๋ฌธ์—)

์ฃผ์š” ๋ฉ”์„œ๋“œ์™€ ํ”„๋กœํผํ‹ฐ

  • new Map() : ๋งต ์ƒ์„ฑ

  • map.set(key,value) : key๋ฅผ ์ด์šฉํ•ด value ์ €์žฅ

  • map.get(key) : key์˜ value ๋ฐ˜ํ™˜. key๊ฐ€ ์—†์œผ๋ฉด undefined

  • map.has(key) : key๊ฐ€ ์กด์žฌํ•˜๋ฉด true, ์—†์œผ๋ฉด false

  • map.delete(key) : key์— ํ•ด๋‹นํ•˜๋Š” value ์‚ญ์ œ

  • map.clear() : ๋งต ๋ชจ๋“  ์š”์†Œ ์ง€์šฐ๊ธฐ

  • map.size : ๋งต์˜ ์š”์†Œ ๊ฐœ์ˆ˜ ๋ฐ˜ํ™˜

  • map.keys() : key๋“ค์„ ๋ชจ์€ iterable๊ฐ์ฒด๋ฅผ ๋ฐ˜ํ™˜

  • map.values() : value๋“ค์„ ๋ชจ์€ iterable ๊ฐ์ฒด๋ฅผ ๋ฐ˜ํ™˜

  • map.entries() : [key,value]๋ฅผ ์Œ์œผ๋กœํ•˜๋Š” iterable๊ฐ์ฒด๋ฅผ ๋ฐ˜ํ™˜

    let recipeMap = new Map([
      ['cucumber', 500],
      ['tomatoes', 350],
      ['onion', 50],
    ]);
    
    for (let vegetable of recipeMap.keys()) {
      alert(vegetable); // cucumber, tomatoes, onion
    }
    
    for (let amount of recipeMap.values()) {
      alert(amount); // 500, 350, 50
    }
    
    alert(recipeMap.entries());
  • forEach() : ๋ชจ๋“  ์š”์†Œ์— ๋Œ€ํ•ด ๋ฐ˜๋ณต์‹คํ–‰

  • Object.entries : ๊ฐ์ฒด๋ฅผ ๋งต์œผ๋กœ ๋ฐ”๊พธ๊ธฐ

    let obj = {
      name: 'John',
      age: 30,
    };
    
    let map = new Map(Object.entries(obj));
    alert(map.get('name')); // John
  • Object.fromEntries : ๋งต์„ ๊ฐ์ฒด๋กœ ๋ฐ”๊พธ๊ธฐ

    let map = new Map();
    map.set('banana', 1);
    map.set('orange', 2);
    map.set('meat', 4);
    
    let obj = Object.fromEntries(map.entries()); // obj = { banana: 1, orange: 2, meat: 4 }
    alert(obj.orange); // 2

WeekMap

์œ„ํฌ๋งต์€ ์ผ๋ฐ˜ ๋งต๊ณผ ๋‹ฌ๋ฆฌ ํ‚ค๋กœ์“ฐ์ธ ๊ฐ์ฒด๊ฐ€ ๊ฐ€๋น„์ง€ ์ปฌ๋ ‰์…˜์˜ ๋Œ€์ƒ์ด ๋œ๋‹ค.

key๊ฐ€ ๋ฐ˜๋“œ์‹œ ๊ฐ์ฒด์ด์–ด์•ผ ํ•œ๋‹ค.

์‚ฌ์šฉ๊ฐ€๋Šฅ ํ•จ์ˆ˜

  • weakMap.get(key)

  • weakMap.set(key, value)

  • weakMap.delete(key)

  • weakMap.has(key)

์‚ฌ์šฉ ์˜ˆ

  • ๋ถ€๊ฐ€์ ์ธ ๋ฐ์ดํ„ฐ๋ฅผ ์ €์žฅํ•  ๊ณณ์ด ํ•„์š”ํ• ๋•Œ

    ์™ธ๋ถ€ ์ฝ”๋“œ์— ์†ํ•œ ๊ฐ์ฒด๋ฅผ ๊ฐ€์ง€๊ณ  ์ž‘์—…์„ ํ• ๋•Œ, ์–ด๋–ค ๊ฐ์ฒด์— ๋ฐ์ดํ„ฐ๋ฅผ ์ถ”๊ฐ€ํ•ด์ค„๋•Œ (๊ตณ์ด ์™ธ๋ถ€ ์ฝ”๋“œ์— ์†ํ•œ ๊ฐ์ฒด๋ฅผ ๋ฉ”๋ชจ๋ฆฌ์— ๋‚จ๊ธธ ํ•„์š”๊ฐ€ ์—†๋‹ค.)

  • ์บ์‹ฑ์ด ํ•„์š”ํ• ๋•Œ

    ๋™์ผํ•œ ํ•จ์ˆ˜๋ฅผ ์—ฌ๋Ÿฌ๋ฒˆ ํ˜ธ์ถœํ• ๋•Œ (์ฒ˜์Œ ์‹คํ–‰๊ฐ’์„ ์—ฌ๋Ÿฌ๋ฒˆ ์‚ฌ์šฉํ• ๋•Œ) ์บ์‹ฑ์„ ์ด์šฉํ•˜๋ฉฐ ์บ์‹œ์— ํ•„์š”์—†์–ด์ง„ ํ•จ์ˆ˜๋ฅผ ์‚ญ์ œํ• ๋•Œ WeekMap์ด ์œ ์šฉํ•˜๋‹ค.

Set

์ค‘๋ณต์„ ํ—ˆ์šฉํ•˜์ง€ ์•Š๋Š” ๊ฐ’๋“ค์„ ๋ชจ์•„๋†“์€ ์ž๋ฃŒ๊ตฌ์กฐ

์ฃผ์š” ๋ฉ”์„œ๋“œ ๋ฐ ํ”„๋กœํผํ‹ฐ

  • new Set(iterable) : iterable๊ฐ์ฒด(๋ฐฐ์—ด, ๊ฐ์ฒด)์„ ์ „๋‹ฌ๋ฐ›์œผ๋ฉด ๊ฐ’์„ ๋ณต์‚ฌํ•ด ์…‹์„ ๋งŒ๋“ค์–ด์ค€๋‹ค.

  • set.add(value) : value๋ฅผ ์ถ”๊ฐ€ํ•˜๊ณ  ์…‹ ์ž์‹ ์„ ๋ฐ˜ํ™˜

  • set.delete(value) : value๋ฅผ ์ œ๊ฑฐํ•˜๊ณ  ์ œ๊ฑฐ๊ฐ€ ์„ฑ๊ณตํ•˜๋ฉด true, ์•„๋‹ˆ๋ฉด false ๋ฐ˜ํ™˜

  • set.has(value) : ์…‹ ๋‚ด์— ๊ฐ’์ด ์กด์žฌํ•˜๋ฉด true, ์•„๋‹ˆ๋ฉด false

  • set.clear() : ์…‹ ์ดˆ๊ธฐํ™”

  • set.size : ์…‹์˜ ์š”์†Œ ๊ฐœ์ˆ˜

  • for...of / forEach : ๋ฐ˜๋ณต์ž‘์—… ์ˆ˜ํ–‰

    let set = new Set(['oranges', 'apples', 'bananas']);
    
    for (let value of set) alert(value);
    
    set.forEach((value, valueAgain, set) => {
      alert(value);
    });

    map๊ณผ set์˜ ์ƒํ˜ธ ๋ณ€ํ™˜์„ ์‰ฝ๊ฒŒํ•˜๊ธฐ ์œ„ํ•ด forEach์— ์“ฐ์ธ ์ธ์ˆ˜๋ฅผ 2๊ฐœ ์‚ฌ์šฉํ•œ๋‹ค.

WeekSet

์œ„ํฌ๋งต์ฒ˜๋Ÿผ ๋ณต์žกํ•œ ๋ฐ์ดํ„ฐ๋ฅผ ์ €์žฅํ•˜์ง€ ์•Š๊ณ  ์˜ˆ, ์•„๋‹ˆ์˜ค์ฒ˜๋Ÿผ ๊ฐ„๋‹จํ•œ ๋‹ต๋ณ€์„ ์–ป๋Š” ์šฉ๋„๋กœ ์‚ฌ์šฉ

์‚ฌ์šฉ๊ฐ€๋Šฅ ํ•จ์ˆ˜

  • weakSet.get(key)

  • weakSet.set(key, value)

  • weakSet.delete(key)

  • weakSet.has(key)

์‚ฌ์šฉ ์˜ˆ

  • ๋ถ€๊ฐ€์ ์ธ ๋ฐ์ดํ„ฐ๋ฅผ ์ €์žฅํ•  ๊ณณ์ด ํ•„์š”ํ• ๋•Œ

    ์™ธ๋ถ€ ์ฝ”๋“œ์— ์†ํ•œ ๊ฐ์ฒด๋ฅผ ๊ฐ€์ง€๊ณ  ์ž‘์—…์„ ํ• ๋•Œ, ์–ด๋–ค ๊ฐ์ฒด์— ๋ฐ์ดํ„ฐ๋ฅผ ์ถ”๊ฐ€ํ•ด์ค„๋•Œ (๊ตณ์ด ์™ธ๋ถ€ ์ฝ”๋“œ์— ์†ํ•œ ๊ฐ์ฒด๋ฅผ ๋ฉ”๋ชจ๋ฆฌ์— ๋‚จ๊ธธ ํ•„์š”๊ฐ€ ์—†๋‹ค.)

  • ์บ์‹ฑ์ด ํ•„์š”ํ• ๋•Œ

    ๋™์ผํ•œ ํ•จ์ˆ˜๋ฅผ ์—ฌ๋Ÿฌ๋ฒˆ ํ˜ธ์ถœํ• ๋•Œ (์ฒ˜์Œ ์‹คํ–‰๊ฐ’์„ ์—ฌ๋Ÿฌ๋ฒˆ ์‚ฌ์šฉํ• ๋•Œ) ์บ์‹ฑ์„ ์ด์šฉํ•˜๋ฉฐ ์บ์‹œ์— ํ•„์š”์—†์–ด์ง„ ํ•จ์ˆ˜๋ฅผ ์‚ญ์ œํ• ๋•Œ WeekMap์ด ์œ ์šฉํ•˜๋‹ค.

Last updated