Android ha un rigido modello di threading incentrato sul thread principale (UI) — che deve gestire l'interfaccia utente e rimanere reattivo. Comprendere il threading, perché il lavoro deve spostarsi dal thread principale, e gli strumenti (coroutine, e storicamente thread/handler) è importante per app reattive.
La regola del thread principale
Android has a single MAIN (UI) thread that:
→ handles ALL UI operations (drawing, events) — UI updates MUST happen on it
→ must stay RESPONSIVE — blocking it freezes the UI; >5s blocked = ANR (App Not Responding)
TWO key rules:
1. DON'T do long/blocking work on the main thread (network, DB, heavy compute) → move it off
2. DON'T update UI from a background thread → switch back to the main thread for UI
