Kotlin Coroutines & Flow
Priority: P1 (HIGH)
Standard for safe, structured asynchronous programming.
Implementation Guidelines
- •Structured Concurrency: Always launch coroutines within a
CoroutineScope(e.g.,viewModelScope,lifecycleScope). Never useGlobalScope. - •Dispatchers: Inject
DispatcherProviderorCoroutineDispatcherto simplify testing. Do not hardcodeDispatchers.IOin classes. - •Suspend Functions: Mark blocking/long-running operations as
suspend. They should be "main-safe" (handle their own context switching). - •Flow: Prefer
StateFlow(state holder) andSharedFlow(events) overLiveData. - •Collection: Use
collectLatestfor restartable upstream updates. UseflowWithLifecyclein UI. - •Error Handling: Use
CoroutineExceptionHandlerfor top-level launch,try/catchfor code blocks within coroutines.
Anti-Patterns
- •GlobalScope: Leaks memory and breaks structure.
- •Blocking Calls: Never use
Thread.sleepor blocking I/O in coroutines. Usedelayor proper suspend functions. - •Async/Await Abuse: Don't use
asyncunless you need parallel execution. Use linear code inlaunch. - •Mutable State in Flow: Don't expose
MutableStateFlowpublicly. Cast toStateFlow.
Code
For detailed ViewModel + StateFlow and Parallel Async examples:
references/advanced-patterns.md
kotlin
// Structured Scope + Main-safe Suspend
viewModelScope.launch {
val data = withContext(Dispatchers.IO) { repo.fetch() }
_state.value = UiState.Success(data)
}
Related Topics
best-practices | language | android