7dc7e0436c
Processed 70+ files covering Skybound mechanics, Frontend mastery, and Business strategy.
2.6 KiB
2.6 KiB
flushSync
📌 Brief Summary
flushSync는 React 18에서 도입된 API로, React가 상태 업데이트를 즉각적이고 동기적으로 강제 적용하도록 만드는 메서드입니다 [1-3]. 이 메서드를 사용하면 React 18의 기본 동작인 자동 배칭(Automatic Batching)에서 예외적으로 벗어나 즉시 리렌더링을 유발할 수 있습니다 [2, 3]. 그러나 과도하게 사용할 경우 배칭을 통한 성능 향상 이점을 무효화할 수 있으므로, DOM 측정이나 즉각적인 폼 업데이트처럼 필수적인 경우에만 제한적으로 사용해야 합니다 [2, 4].
📖 Core Content
- 개념 및 역할: React 18부터는 성능 최적화를 위해 여러 상태 업데이트를 단일 리렌더링으로 묶는 자동 배칭(Automatic Batching)이 기본적으로 적용됩니다 [5-7]. 하지만 ReactDOM에 포함된
flushSync()메서드를 사용하면 이 자동 배칭을 의도적으로 우회(Opt-out)하여, 특정 상태 업데이트 시 React가 업데이트를 동기적으로 처리하고 즉시 리렌더링하도록 강제할 수 있습니다 [1, 3]. - 적절한 사용 사례(Use Cases):
flushSync는 사용자가 변경 사항을 지연 없이 즉각적으로 보아야 하는 매우 긴급한 업데이트에 사용됩니다 [2].- 사용자의 입력 지연을 방지하기 위해 폼(Form) 값을 즉시 업데이트할 때 [2].
- 상태 변경 직후 특정 DOM 요소에 포커스(Focus)를 주거나, DOM 요소의 크기/위치를 측정(Measure)해야 할 때 [2].
- 사용 방법: 상태 업데이트 로직을 래핑하여 사용합니다. (예:
flushSync(() => { setValue(''); });) [2]. - 성능 관련 주의사항: 자동 배칭은 렌더링 횟수를 줄여 성능을 향상시키는 핵심 기능이므로,
flushSync를 남용하면 이러한 성능상 이점이 무효화될 수 있습니다 [4]. 따라서 가급적 드물게(sparingly) 사용해야 합니다 [4].
🔗 Knowledge Connections
- Related Topics: Automatic Batching, React 18, startTransition
- Projects/Contexts: DOM Element Measurement, Form Value Synchronization
- Contradictions/Notes: React 18의 상태 업데이트 제어 방식 중
flushSync는 업데이트를 즉시 동기적으로 강제(Force synchronously)하는 반면,startTransition은 업데이트를 비긴급(Non-urgent)으로 지정하여 더 높은 우선순위 작업(타이핑, 클릭 등)에 메인 스레드를 양보한다는 점에서 상반된 목적을 가집니다 [1, 2].
Last updated: 2026-04-25