20 lines
2.6 KiB
Markdown
20 lines
2.6 KiB
Markdown
# [[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* |