동작원리3 [Node] 비동기 함수의 동작 방식 최근에 내가 하고 있는 부스트캠프 챌린지에서 비동기 관련 미션이 나와 푸는데 애를 먹었던 적이 있었다. 예전부터 비동기에 대한 개념이 너무 부족한걸 알았지만 끝끝내 미뤘는데 이번 기회에 정리를 해야겠다고 생각했다. 예시를 보면서 확인하겠습니다. 코드 상으로는 다음과 같습니다. console.log('Hi'); setTimeout(function cb(){ console.log('there'); }); console.log('JSConfEU'); 메서드들은 호출 스택에 쌓일 것이기 때문에 일반적으로 console.log('Hi')가 동작되고 setTimeout()이 동작하고 마지막으로 console.log('JSConfEU')가 동작할 것이라고 예상합니다. 그러나 setTimeout()은 비동기 메서드이기.. 2021. 8. 7. [자료구조] Map 살펴보기 Map이란? Map은 기존의 JFC와는 다르게 Key, Value가 존재한다. Key는 중복을 허용하지 않는 ID값이며, Value는 중복을 허용하는 Data 값이다. 또한 기본적으로 Map은 순서를 유지하고 있지 않는다. 가장 대표적인 Map의 예시로는 주민등록번호, ID/PW 이다. Map이라는 인터페이스를 통해 자바에서는 4가지의 Map이 있다. Hash 알고리즘을 이용한 HashMap HashMap의 이전 버전인 HashTable(Vector와 ArrayList 같은 관계) 이진 탐색 트리를 사용하여 키를 오름차순 정렬까지 해주는 TreeMap Map에 순서를 부여해주는 LinkedHashMap 왜 Map을 사용해야하나? Map의 특징은 Key, Value로 나뉘고 순서가 없고 Key는 중복을 허.. 2021. 7. 16. [자료구조] Set 살펴보기 Set이란? Set은 집합이라는 의미를 가진다. Set은 JFC에 있는 자료구조로 순서가 없고 중복을 허용하지 않는다. 즉, 집합의 개념과 같다고 생각하면 된다.(집합 역시 {1, 9, 6, 4}처럼 중복과 순서가 없다.) Set이라는 인터페이스를 통해 자바에서는 3가지의 Set이 있다. Hash 알고리즘을 이용한 HashSet 이진 탐색 트리를 사용하여 오름차순 정렬까지 해주는 TreeSet Set에 순서를 부여해주는 LinkedHashSet 일반적으로 HashSet, TreeSet, LinkedHashSet 순으로 빠르다. 왜 Set을 사용해야하나? Set의 가장 큰 특징은 바로 순서가 없고 중복을 허용하지 않는다는 것이다. 따라서 비록 위 특징을 List나 다른 자료구조를 통해 커버할 수 있지만 명.. 2021. 7. 16. 이전 1 다음