Files
2nd/10_Wiki/Topics/Frontend_Mastery/flushSync.md
T

2.7 KiB

flushSync

📌 Brief Summary

flushSyncReact 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|startTransition]]은 업데이트를 비긴급(Non-urgent)으로 지정하여 더 높은 우선순위 작업(타이핑, 클릭 등)에 메인 스레드를 양보한다는 점에서 상반된 목적을 가집니다 [1, 2].

Last updated: 2026-04-25