JavaScript

[ES6 JavaScript] Set

코딩하는 Jay 2020. 10. 11. 09:24
반응형

 안녕하세요. 오늘은 Set에 대해 공부해보도록 하겠습니다. Set 객체는 값 Collection으로 요소 삽입 순서를 기억합니다. 그렇기 때문에 삽입 순서대로 순회가 가능합니다. 또 하나의 Set내 값은 한 번만 나타날 수 있습니다. 즉, 어떤 값은 그 Set에서 유일합니다. 

 

Pixabay 로부터 입수된  pencil parker 님의 이미지 입니다.

 

var mySet = new Set();

mySet.add(1); // Set { 1 }
mySet.add(5); // Set { 1, 5 }
mySet.add(5); // Set { 1, 5 }
mySet.add('some text'); // Set { 1, 5, 'some text' }
var o = {a: 1, b: 2};
mySet.add(o);

mySet.add({a: 1, b: 2}); // o와 다른 객체를 참조하므로 괜찮음

mySet.has(1); // true
mySet.has(3); // false, 3은 set에 추가되지 않았음
mySet.has(5);              // true
mySet.has(Math.sqrt(25));  // true
mySet.has('Some Text'.toLowerCase()); // true
mySet.has(o); // true

mySet.size; // 5

mySet.delete(5); // set에서 5를 제거함
mySet.has(5);    // false, 5가 제거되었음

mySet.size; // 4, 방금 값을 하나 제거했음
console.log(mySet);// Set {1, "some text", Object {a: 1, b: 2}, Object {a: 1, b: 2}}

 위 예제 4, 5번째 라인에서 5를 두 번 add 하는 것을 확인할 수 있습니다. 4번째 라인에서 add를 통해 5가 Set에 추가된 것을 확인할 수 있지만, 5번째 라인에서는 추가되지 않았습니다. 이미 5가 Set에 존재하기 때문입니다. 기존 값과 추가될 값에 대한 비교는 === 연산자를 이용합니다. 8번째 라인에서 o객체는 추가했습니다. 그리고 10번째 라인에서 o와 동일한 모양의 객체를 추가하고 있습니다. 그런데, 추가가 잘 되는 것을 확인할 수 있씁니다. 그 이유는 8, 10번째 라인에서의 객체들의 레퍼런스가 다르기 때문입니다. 

 

// set 내 항목에 대해 반복
// 순서대로 항목을 (콘솔에) 기록: 1, "some text", {"a": 1, "b": 2} 
for (let item of mySet) console.log(item);

// 순서대로 항목을 기록: 1, "some text", {"a": 1, "b": 2} 
for (let item of mySet.keys()) console.log(item);

// 순서대로 항목을 기록: 1, "some text", {"a": 1, "b": 2} 
for (let item of mySet.values()) console.log(item);

// 순서대로 항목을 기록: 1, "some text", {"a": 1, "b": 2} 
// (여기서 key와 value는 같음)
for (let [key, value] of mySet.entries()) console.log(key);

// Set 객체를 배열 객체로 변환 (Array.from으로)
var myArr = Array.from(mySet); // [1, "some text", {"a": 1, "b": 2}]

// 다음도 HTML 문서에서 실행하는 경우 작동함
mySet.add(document.body);
mySet.has(document.querySelector('body')); // true

// Set과 Array 사이 변환
mySet2 = new Set([1, 2, 3, 4]);
mySet2.size; // 4
[...mySet2]; // [1, 2, 3, 4]

// 교집합은 다음으로 흉내(simulate)낼 수 있음
var intersection = new Set([...set1].filter(x => set2.has(x)));

// 차집합은 다음으로 흉내낼 수 있음
var difference = new Set([...set1].filter(x => !set2.has(x)));

// forEach로 set 항목 반복
mySet.forEach(function(value) {
  console.log(value);
});

// 1
// 2
// 3
// 4

 위 코드를 통해서는 다양한 방법으로 Set을 반복할 수 있는 것을 확인할 수 있습니다. 처음 3번의 for...of 문에서 확인할 수 있듯이 키-값 쌍으로 이루어진 Map과는 달리 모두 같은 출력을 확인할 수 있습니다. Map과 동일한 방법으로 출력할 수 있지만, Set은 키와 값이 동일한 값을 같습니다. 

 

var myArray = ['value1', 'value2', 'value3', 'value3'];

// Array를 Set으로 변환하기 위해서는 정규 Set 생성자 사용
var mySet = new Set(myArray);

mySet.has('value1'); // true 반환

// set을 Array로 변환하기 위해 전개 연산자 사용함.
console.log([...mySet]); // myArray와 정확히 같은 배열을 보여줌

 Array 객체를 Set 으로 변환할 수 있습니다. 단, Array와 달리 Set은 중복이 불가능하기 때문에 데이터가 사라질 수도 있습니다. 위 예제에서도 value3이 동일하게 2번 등장하지만 Set으로 변환시 하나만 추가된 것을 확인할 수 있습니다.

반응형

'JavaScript' 카테고리의 다른 글

[ES6 JavaScript] WeakSet  (0) 2020.10.15
[ES6 JavaScript] WeakMap  (0) 2020.10.13
[ES 6 JavaScript] Map  (0) 2020.10.10
[ES6 JavaScript] Generator  (0) 2020.10.07
[ES6 JavaScript] for...of  (0) 2020.10.06