PHPz2017-04-24 09:12:21
操作的原子性保證操作不可再分,要麼完整執行要麼完整不執行。
作業系統原理要學原子性的。時間有點久可能說的不太準確,舉個跟Redis沒關係的普通例子。
有個變數A=10,我要給它加5。那我的「加5」操作要分成幾個步驟:
有另外一個人要給它加3,他不知道我也要操作A變量,他的「加3」操作要分為幾個步驟:
如果我們的操作(「加3」和「加5」)不是原子性的,互相之間的指令會亂排,無法預料結果,可能他先完成了+3的回寫,我讀的時候已經是13,於是得到了+3再+5的正確結果。也有可能他還在+3的運算中沒有寫回,我剛好讀到了10,於是回寫的時候有可能是13也有可能是15。
如果我們的操作是原子性的,就可以保證他在進行加3操作的步驟的時候我無法插入其中,在他完成操作後我才能開始進行我的操作,從而保證數據是可靠的。