Sytuacja w programowaniu współbieżnym, w której jeden wątek zapisuje wartość zmodyfikowaną przez inny wątek ignorując tę modyfikację. Klasycznym przykładem przytaczanym w literaturze przedmiotu jest dokonywanie przelewów bankowych, które są operacjami podzielnymi.
Instrukcja ta może zostać wykonana w następujący sposób:
1. Załadowanie wartości do rejestru.
2. Zwiększenie wartości.
3. Zapisanie wyniku.
Wyobraźmy sobie teraz, że pierwszy z wątków wykonuje dwa pierwsze kroki i zostaje wywłaszczony. Następnie budzi się drugi wątek, który aktualizuje tę samą pozycję. Potem budzi się pierwszy wątek i kończy działanie, wykonując krok trzeci.
Ta czynność wymazuje zmiany dokonane przez drugi wątek, w wyniku czego zmienia się ogólna suma.