2.3.3 操作系统之实现临界区进程互斥的硬件实现方法
                                                            生活随笔
收集整理的這篇文章主要介紹了
                                2.3.3  操作系统之实现临界区进程互斥的硬件实现方法
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.                        
                                文章目錄
- 0.思維導圖
 - 1.中斷隱藏方法
 - 2.TestAndSet指令
 - 3.Swap指令
 
0.思維導圖
1.中斷隱藏方法
2.TestAndSet指令
- 執行TSL指令時,它的內部運轉邏輯:
 - 假設lock現在為false,代表臨界資源A空閑,那么我就可以訪問這個資源,同時將lock=true,提醒別的進程,這個臨界資源A我正在使用,讓他們等等
 - 假設lock為true,代表臨界資源正在有人使用,所以我必須等待,并且將lock=true,并不影響什么,所以沒關系,只是為了讓lock為false時可以上鎖,將上鎖與檢查在一個TSL指令完成。
 
3.Swap指令
- old是每個進程都要進行的一步,都必須將old=true
 - 分析一下這樣做的原因:
 - 因為lock是某一特定臨界資源的共享變量,當每一個進程準備訪問這個特定的臨界資源時,初始化old=true,然后進入while循環進行交換,如果當前lock是false,則交換后old=false,則當前進程可以跳出循環進入臨界區代碼段,同時因為交換,lock=old=true上鎖,不讓別的進程來打擾,別的進程會因為lock變為true,一直在while循環等待,當我使用完臨界資源,則將lock=false,此時別的進程再交換old和lock就能判斷old=false,可以跳出循環,使用臨界資源。
參考:https://www.bilibili.com/video/av70156862?p=19 
總結
以上是生活随笔為你收集整理的2.3.3 操作系统之实现临界区进程互斥的硬件实现方法的全部內容,希望文章能夠幫你解決所遇到的問題。
                            
                        - 上一篇: 2.3.2 操作系统之实现临界区进程互斥
 - 下一篇: 2.3.4 操作系统之信号量机制(整型信