상식닷컴
로그인
가입하기
2026년 상식닷컴 선정 식당 & 카페 리스트
2025년 2026년 신상 호텔 리스트
최근에 오픈한 호텔을 찾는다면 살펴보세요
일주일 식단표 어플
자동 일주일 식단표 어플
안드로이드
아이폰
주식 & 코인 차트의 신
1000만원으로 2000만원 만들기 프로젝트
궁금한 상식 보기
파킨슨병 환자의 치료 계획은 어떻게 수립되나요?
Lose와 Miss의 차이점은?
빗썸에서 암호화폐의 시장 분석 도구는 어떤 것이 있나요?
호찌민시의 유명한 커피 브랜드는 무엇인가요?
밴쿠버의 문화 행사나 축제는 어떤 것이 있나요?
캘거리의 교육 시스템은 어떤가요?
캘거리의 주요 농산물은 무엇인가요?
낭트의 주요 전시회는 어떤 것이 있나요?
개인회생 절차에서 채무자의 신용 회복은 어떻게 이루어지나요?
개인회생 절차에서 채무자의 상환 계획이 변경되면 어떤 절차가 있나요?
지방세의 세금 납부를 위한 인터넷 결제 시스템은 무엇이 있나요?
지방세의 세금 환급을 위한 신청서 작성 시 유의사항은 무엇인가요?
Previous
Next
수정하기 - switchMap과 mergeMap을 혼합 사용하는 방법은 무엇인가요?
닉네임
비밀번호
제목
내용
[이미지 업로드는 권한이 있는 사람만 가능. 하단 카톡으로 연락]
switchMap과 mergeMap은 RxJS에서 Observable을 변환하거나 연쇄적으로 처리할 때 자주 사용하는 연산자입니다. 각각의 특징과 용도를 이해하고, 상황에 따라 두 연산자를 혼합해서 사용하는 방법을 아는 것은 복잡한 비동기 흐름을 관리하는 데 매우 유용합니다. --- switchMap과 mergeMap의 역할 간략 정리 - switchMap 내부 Observable이 새로 생성되면 이전에 구독 중인 Observable을 취소하고 최신 Observable만 구독한다. 즉, 최신 요청이나 이벤트에 집중하고 이전 요청들은 무시할 때 유용하다. - mergeMap 내부 Observable들이 여러 개 있을 때, 모두 병렬로 구독하고 결과를 병합한다. 즉, 모든 요청의 결과를 받아 처리하고 싶을 때 사용한다. --- 혼합 사용하는 이유 비동기 작업 중 특정 시점에는 "마지막 요청만 필요(예: 자동완성 검색)"하고 또 다른 시점에는 "동시에 여러 비동기 작업을 병렬로 처리해야 할 때"가 있습니다. 이 두 가지 요구 사항이 혼재된 복잡한 스트림 처리에서는 동시에 둘 다 쓰는 경우가 많습니다. --- 혼합 사용하는 기본 개념 1. 외부 스트림에서 switchMap 사용 외부 입력이나 이벤트 스트림이 있을 때, 이벤트가 빠르게 연속해서 발생한다면 switchMap으로 이전 이벤트의 내부 Observable을 취소하고 최신 이벤트만 처리하도록 한다. 2. 내부 Observable 생성 시 mergeMap 사용 switchMap 내부에서 반환하는 Observable은 mergeMap으로 여러 개의 비동기 작업 또는 요청을 병렬적으로 실행하도록 한다. 즉, 먼저 외부 이벤트 흐름을 "최신 이벤트 중심"으로 관리하다가, 내부적으로는 각 이벤트에 여러 비동기 작업을 동시에 병렬로 실행하는 패턴입니다. --- 실무 예시로 설명 예를 들어, 사용자의 검색어 입력 이벤트가 있다고 합시다. - 사용자가 입력을 연속해서 빠르게 하면 이전 입력에 따른 네트워크 요청은 취소하고 최신 입력에 대한 요청만 처리해야 합니다 → switchMap - 검색어에 대해 여러 API를 병렬로 호출해야 한다(예: 사용자 정보 검색 + 상품 검색 + 뉴스 검색) → 각각의 API 호출은 별개의 비동기 작업이므로 내부에서 mergeMap 으로 병렬 처리 ```typescript input$.pipe( debounceTime(300), switchMap(searchTerm => { // 내부에서 여러 개의 API 호출을 병렬로 처리 return of(searchTerm).pipe( mergeMap(term => httpSearchUsers(term)), mergeMap(term => httpSearchProducts(term)), mergeMap(term => httpSearchNews(term)), // 필요에 따라 forkJoin, combineLatest 등을 써서 결과 병합을 조절할 수도 있음 ); }) ).subscribe(results => { // results를 처리 }); ``` 위 예는 다소 단순화한 형태지만, 핵심은 외부 이벤트를 switchMap으로 최신 이벤트만 처리하면서 내부에서는 여러 비동기 요청을 mergeMap으로 병렬 병합 처리하는 구조라는 점입니다. --- 응용 - 내부 mergeMap으로 여러 요청 병렬 처리 후 결과 합치기 mergeMap으로 여러 Observable을 처리하다가 결과를 하나로 묶고 싶다면 forkJoin이나 combineLatest와 결합할 수 있습니다. - 내부에 다시 switchMap 사용 내부 비동기 연쇄작업 중에도, 예를 들어 일부 요청은 취소가 필요하면 내부에서 다시 switchMap을 쓸 수도 있습니다. - 중첩 조합 상황에 따라 switchMap 내부에서 mergeMap을 쓰기도 하고, mergeMap 내부에서 다시 switchMap을 쓰는 등 복잡한 상호작용 구조를 설계할 수 있습니다. --- 요약 - 외부 이벤트 스트림 → switchMap (이전 처리 취소, 최신 이벤트만 주목) - 내부 비동기 병렬 처리 → mergeMap (여러 내부 Observable 병렬 실행) - 필요에 따라 forkJoin, combineLatest 등과 결합하여 결과를 한꺼번에 묶거나 분석 이렇게 두 연산자를 적절히 혼합하면 복잡한 비동기 스트림 제어가 가능해지고, 불필요한 요청을 줄이면서 동시에 여러 비동기 요청을 효율적으로 처리할 수 있습니다.
이용안내
커뮤니티 이용안내
×
- 게시한 게시글로 발생하는 문제는 게시자에게 책임이 있습니다.
- 게시글이 타인/타업체의 저작권을 침해할 경우 모든 책임은 게시자에게 있습니다. 게시자가 모든 손해를 부담해야 합니다.
- 상식닷컴 운영자는 게시자와 상의하지 않고 게시글을 수정 또는 삭제할 수 있습니다.
- 상식닷컴 운영자는 깨끗한 커뮤니티 공간을 만드는 것이 1순위입니다.
수정하기
취소하기