상식닷컴
로그인
가입하기
2026년 상식닷컴 선정 식당 & 카페 리스트
2025년 2026년 신상 호텔 리스트
최근에 오픈한 호텔을 찾는다면 살펴보세요
일주일 식단표 어플
자동 일주일 식단표 어플
안드로이드
아이폰
주식 & 코인 차트의 신
1000만원으로 2000만원 만들기 프로젝트
수정하기 - switchMap을 사용하여 성능 데이터를 수집하는 방법은?
닉네임
비밀번호
제목
내용
[이미지 업로드는 권한이 있는 사람만 가능. 하단 카톡으로 연락]
switchMap은 RxJS에서 사용하는 연산자로, 주로 Observable 내에서 비동기 작업을 처리할 때 이전 비동기 작업을 취소하고 새로운 작업으로 전환하여 최신 데이터 흐름을 유지하는 데 유용합니다. 성능 데이터를 수집할 때 switchMap을 적절히 활용하면, 예를 들어 사용자 입력 또는 이벤트에 따라 성능 모니터링 API 또는 데이터 소스에 대한 호출을 효율적으로 관리할 수 있습니다. switchMap을 사용한 성능 데이터 수집 방법 1. 상황 설정 예를 들어 애플리케이션에서 사용자가 실시간으로 필터를 변경하거나 특정 서버의 성능 지표를 조회한다고 가정합시다. 이때 성능 데이터는 비동기 요청을 통해 API에서 받아오거나, 웹소켓 혹은 다른 스트림 형태로 수신할 수 있습니다. 2. Observable 흐름 생성 성능 데이터를 수집할 때, 일반적으로 다음과 같은 이벤트 스트림이 있습니다. - 사용자 입력(검색어, 필터, 선택 등) - 주기적인 타이머 (예: 5초마다 최신 데이터 갱신) - 기타 이벤트 (예: 환경 설정 변경) 이 이벤트들을 Observable로 만들고, 이들을 기반으로 API 호출 Observable을 생성합니다. 3. switchMap 적용 `switchMap`은 내부 Observable(예: API 호출 결과)을 반환하는 고차 Observable 연산자입니다. 중요한 특징은 내부 Observable 실행 중에 새로운 값이 들어오면 이전 Observable을 취소(구독 해제)하고 최신 Observable로 전환한다는 점입니다. 이렇게 하면 이전 요청의 응답이 늦게 도착하더라도 마지막 요청 데이터로만 화면이나 상태를 갱신하여 불필요한 작업과 리소스 낭비를 줄일 수 있습니다. 4. 구현 예시 ```typescript import { fromEvent, timer } from 'rxjs'; import { debounceTime, switchMap, distinctUntilChanged } from 'rxjs/operators'; import { ajax } from 'rxjs/ajax'; // 예: 검색어 입력으로 서버에서 성능 데이터를 가져오는 경우 const searchInput = document.getElementById('searchBox'); const search$ = fromEvent(searchInput, 'input').pipe( debounceTime(300), // 사용자가 타이핑 멈출 때까지 대기 distinctUntilChanged(), // 이전과 다른 값일 때만 진행 switchMap((event: any) => { const query = event.target.value; return ajax.getJSON(`/api/performance?query=${query}`); }) ); search$.subscribe({ next: data => { // 받은 성능 데이터로 UI 업데이트 console.log('성능 데이터:', data); }, error: err => console.error('에러 발생:', err) }); ``` 5. 성능 최적화 - 불필요한 API 호출 방지 : debounceTime, distinctUntilChanged 같은 연산자와 함께 switchMap을 사용하면, 사용자의 짧은 입력 변동마다 API가 호출되는 일이 줄어듭니다. - 최신 데이터 유지 : switchMap이 최신 요청을 취소하기 때문에 네트워크 지연 상황에서도 오래된 데이터가 UI에 반영되는 상황을 방지합니다. - 메모리 관리 : 이전 Observable이 구독 해제되므로 메모리 누수가 줄어듭니다. 6. 주기적인 성능 데이터 갱신에 적용하기 만약 주기적으로 성능 데이터를 갱신하려면, timer나 interval Observable과 switchMap을 결합할 수 있습니다. ```typescript import { timer } from 'rxjs'; import { switchMap } from 'rxjs/operators'; import { ajax } from 'rxjs/ajax'; const performanceData$ = timer(0, 5000).pipe( // 5초마다 실행 switchMap(() => ajax.getJSON('/api/performance')) ); performanceData$.subscribe(data => { // UI 갱신 등 처리 console.log('주기적 성능 데이터:', data); }); ``` 요약 switchMap을 통해 성능 데이터 수집 시 다음과 같은 이점을 얻습니다. - 사용자 입력이나 이벤트에 따른 중복 요청을 줄인다. - 이전 요청을 신속하게 취소하여 네트워크 리소스 낭비 방지. - 항상 최신 데이터로 UI 상태를 유지. - 비동기 요청과 이벤트 스트림을 효율적으로 결합. 이 원칙을 바탕으로 적절한 RxJS 연산자와 함께 switchMap을 사용하면 실시간으로 변하는 성능 데이터를 효율적이고 안정적으로 수집하고 관리할 수 있습니다.
이용안내
커뮤니티 이용안내
×
- 게시한 게시글로 발생하는 문제는 게시자에게 책임이 있습니다.
- 게시글이 타인/타업체의 저작권을 침해할 경우 모든 책임은 게시자에게 있습니다. 게시자가 모든 손해를 부담해야 합니다.
- 상식닷컴 운영자는 게시자와 상의하지 않고 게시글을 수정 또는 삭제할 수 있습니다.
- 상식닷컴 운영자는 깨끗한 커뮤니티 공간을 만드는 것이 1순위입니다.
수정하기
취소하기