Топ питань
Часова шкала
Чат
Перспективи
Обмін (інформатика)
З Вікіпедії, вільної енциклопедії
Remove ads
О́бмін (англ. swap), в інформатиці — операція для обміну значень аргументів.
Наприклад, якщо маємо дві змінні A та B, і стан пам'яті: A=1, B=2, то після виконання операції swap(A,B)
стан пам'яті змінюється на такий: A=2, B=1.
Реалізації
Очевидна реалізація використовує тимчасову змінну:
- TMP = A
- A = B
- B = TMP
Існують реалізації без використання додаткової змінної, наприклад Алгоритм обміну XOR, або за допомогою арифметики:
- A = A + B
- B = A - B
- A = A - B
В архітектурі x86 замість трьох інструкцій ассемблера MOV можна використовувати одну XCHG[1]. Існує також додаткова інструкція CMPXCHG, яка атомарно виконує дві дії (порівняти і обміняти) і використовується для реалізації мютексів.[2]
Remove ads
Застосування
Див. також
Зноски
Література
Wikiwand - on
Seamless Wikipedia browsing. On steroids.
Remove ads