執行緒切換與程序切換以及開銷

2021-09-25 14:43:52 字數 561 閱讀 9170

為了更好的了解上下文切換,需要我們了解虛擬記憶體的概念。

虛擬記憶體是作業系統為每個程序提供的一種抽象,每個程序都有屬於自己的、私有的、位址連續的虛擬記憶體,當然我們知道最終程序的資料及**必然要放到物理記憶體上,那麼必須有某種機制能記住虛擬位址空間中的某個資料被放到了哪個物理記憶體位址上,這就是所謂的位址空間對映,也就是虛擬記憶體位址與物理記憶體位址的對映關係,那麼作業系統是如何記住這種對映關係的呢,答案就是頁表,頁表中記錄了虛擬記憶體位址到物理記憶體位址的對映關係。有了頁表就可以將虛擬位址轉換為物理記憶體位址了,這種機制就是虛擬記憶體。

每個程序都有自己的虛擬位址空間,程序內的所有執行緒共享程序的虛擬位址空間。

切換虛擬位址空間

,切換核心棧和硬體上下文

切換核心棧和硬體上下文

最顯著的效能損耗是將儲存暫存器中的內容

cpu快取記憶體失效

頁表查詢是乙個很慢的過程,因此通常使用cache來快取常用的位址對映,這樣可以加速頁表查詢,這個cache就是tlb.當程序切換後頁表也要進行切換,頁表切換後tlb就失效了,cache失效導致命中率降低,那麼虛擬位址轉換為實體地址就會變慢,表現出來的就是程式執行會變慢

程序切換與執行緒切換

原文 為了控制程序的執行,核心必須有能力掛起正在cpu上執行的程序,並恢復以前掛起的某個程序的執行。這種行為被稱為程序切換 process switch 任務切換 task switch 或上下文切換 content switch 程序切換分兩步 1.切換頁目錄以使用新的位址空間 2.切換核心棧和硬...

程序切換與執行緒切換

為了更好的了解上下文切換,需要我們了解虛擬記憶體的概念。虛擬記憶體是作業系統為每個程序提供的一種抽象,每個程序都有屬於自己的 私有的 位址連續的虛擬記憶體,當然我們知道最終程序的資料及 必然要放到物理記憶體上,那麼必須有某種機制能記住虛擬位址空間中的某個資料被放到了哪個物理記憶體位址上,這就是所謂的...

執行緒切換的開銷

從單執行緒應用到多執行緒應用帶來的不僅僅是好處。也會帶來開銷。不要僅僅在乙個應用中使用多執行緒僅僅是因為你能夠 會 使用多執行緒。你應該能確定使用多執行緒帶來的好處要遠遠多於它帶來的花銷。如果不能夠確定,那麼請嘗試測量應用的效能和響應性,不僅僅是猜測。儘管多執行緒應用的某些部分要比單執行緒應用更加簡...