目錄
一、現代電腦硬體結構
1.CPU內部結構
1.1.CPU快取結構
1.2.CPU運作安全等級
)。
首頁 Java java教程 Java底層作業系統與並發基礎有哪些

Java底層作業系統與並發基礎有哪些

Apr 29, 2023 pm 09:25 PM
java

一、現代電腦硬體結構

Java底層作業系統與並發基礎有哪些

 核心部分: CPU、記憶體

1.CPU內部結構

Java底層作業系統與並發基礎有哪些

  • #控制單元: 整個CPU 的指揮控制中心

  • 運算單元: 運算器核心,執行算術運算與邏輯運算。運算元接收控制單元的指令而執行動作

  • 儲存單元: CPU 中暫時儲存資料的地方,包括 CPU 片內快取Cache 與 暫存器群組

1.1.CPU快取結構

現代CPU 為了提升執行效率,減少CPU 與記憶體的交互作用(交互作用影響CPU效率),一般在CPU上整合了多層次快取架構,常見的為三級快取結構

  • #L1 Cache,分為資料快取與指令緩存,邏輯核獨佔

  • L2 Cache,物理核獨佔,邏輯核共享

  • #L3 Cache,所有物理核共享

Java底層作業系統與並發基礎有哪些

此機器的三級快取架構如下圖:L1 Cache又分為兩種,指令儲存單元(儲存指令),和邏輯儲存單元(存邏輯)。理論上一台機器可以有多個 CPU,由插槽決定,一個 CPU 又有多核心,一個核心又可以由多個邏輯處理器。

Java底層作業系統與並發基礎有哪些

暫存器是 CPU 內部元件,讀寫速度非常快。  CPU 讀取資料只會從暫存器中去取,每個 CPU 都有一個獨特的暫存器,其他 CPU 無法存取。 採用暫存器,可以減少 CPU 存取記憶體的次數,從而提高了 CPU 的工作速度。

越靠近CPU 讀取速度越快,摩爾定律中,CPU 以每18個月翻一番的速度在發展,而記憶體和硬碟的發展速度遠遠跟不上。為了解決 CPU 運算速度和 I\O 速度不匹配的問題,CPU 開始被內建了少量的高速緩存 Lx Cache(CPU空間有限,儲存元件大小受限)。

  • 記憶體儲存空間大小: 記憶體> L3 Cache > L2 Cache > L1 Cache > 暫存器

  • #記憶體讀取速度快慢: 暫存器> L1 Cache > L2 Cache > L3 Cache > 記憶體

  • 快取是由最小的存儲區塊--- 快取行(CacheLine) 組成,快取行大小通常為64byte。我的機器L1的快取大小時512K,則由512 * 1024/64個快取行組成。

CPU讀取記憶體資料過程: CPU 只能直接從暫存器取得資料。  假設資料x = 0 在記憶體中,則它的取值過程如下:

#判斷暫存器中是否存在

不存在則遍歷L1 Cache 看是否存在,不存在遍歷L2 Cache,L2 Cache 中沒有,遍歷L3 Cache。中間過程存在,則會把 Cache 行鎖住,拷貝到上一層,直到到暫存器。

Cache 中沒有則區記憶體中找,先通知記憶體控制器佔用匯流排頻寬,通知記憶體加鎖,發起記憶體讀取請求,等待回應,回應資料拷貝到L3 Cache。注意:整個流程加鎖直到到CPU才會解開

局部性原理:在CPU存取儲存裝置時,無論是存取資料或存取指令,都趨於聚集在一片連續的區域中。

這種局部性原理又有兩種:

  • #時間局部性(Temporal Locality): 如果一個資訊項正在被訪問,那麼在近期它很可能還會再次被訪問。例如循環、遞歸、方法的反覆呼叫等。

  • 空間局部性(Spatial Locality): 如果一個記憶體的位置被引用,那麼將來他附近的位置也會被引用。例如依序執行的程式碼、連續建立的兩個物件、陣列等。

空間局部性的例子: 一個很大的二維數組,累加求和一行一行加上會比一列一列累加快很多。在CPU 在記憶體中讀取資料時會將附件的資料都讀進去。

1.2.CPU運作安全等級

CPU被分割為4 個運作等級:

  •  ring0 核心狀態

  • ring1

  •  ring2

  • ring3 使用者狀態

#Linux 和Windows 都只用到了兩個級別:ring0ring3,作業系統內部內部程式指令通常運行在ring0 級別,作業系統以外的第三方程式運行在ring3 級別,第三方程式如果要呼叫作業系統內部函數功能,由於運行安全級別不夠,必須切換CPU運行狀態,從ring3 切換到ring0, 然後執行系統函數,創建線程,線程阻塞喚醒是重型操作,因為CPU要切換運轉狀態。

JVM 建立執行緒是CPU 的流程:

  • 第一步:CPU 從ring3 切換ring0 建立執行緒

  • #第二步:建立完畢,CPU從ring0 切回ring3

  • #第三個步驟:執行緒執行JVM程式

第四步: 執行緒執行完畢,銷毀切回 ring0

Java底層作業系統與並發基礎有哪些

第五步:執行緒銷毀,切回 ring3

    2.作業系統記憶體管理
  • 為了讓程式運行安全隔離與穩定,作業系統有用戶空間

    核心空間
  • 兩個概念。以32位元作業系統4G大小的記憶體空間為例:
  • Linux 為核心程式碼和資料結構預留了幾個頁框,這些頁永遠不會被轉出到磁碟上(4GB記憶體空間,使用者程式可使用3GB)。如圖綠色部分的線性位址可由
  • 使用者程式碼和核心程式碼
來引用(

即使用者空間Java底層作業系統與並發基礎有哪些)。黃色部分的線性位址

只能由核心程式碼

進行存取(

即核心空間

)。

行程與執行緒只能運作在使用者方式(usermode) 或 核心方式(kernelmode) 下。用戶程式運行在用戶方式下,而係統呼叫運行在核心方式下。

使用者方式下使用一般的堆疊(用戶空間的堆疊),核心方式下使用固定大小的堆疊(核心空間的堆疊,一般為一個記憶體頁的大小),即每個行程都與執行緒其實有兩個堆疊,分別運行與用戶態核心態

CPU調度的基本單位線程,也分割為:

Java底層作業系統與並發基礎有哪些

    核心執行緒模型(KLT):
  •  Java使用,內核保存線程的狀態和上下文訊息,線程阻塞不會引起進程阻塞。在多處理器系統上,多執行緒在多處理器上並行運行。執行緒的建立、調度和管理由核心完成,效率比ULT慢,比行程操作快。

  • 使用者執行緒模型(ULT):
  •  不依賴作業系統核心,應用提供建立、同步、調度和管理執行緒的函數來控制使用者執行緒。不需要使用者態/核心態切換,速度快。核心對ULT無感知,執行緒阻塞則行程(包含它的所有執行緒)阻塞

  • # 執行緒都有兩個堆疊,一個在使用者空間,一個在內核空間。阻塞、創建、殺死執行緒將拋棄用戶空間的堆疊,轉移到核心空間,執行完畢後再轉移到用戶空間。 3.進程與執行緒

進程:### ###作業系統資源分配的最小單位###,例如:啟動一個Java 程序,作業系統就會建立一個Java 進程,進程中可以包含多個執行緒。 #########執行緒:### ###作業系統調度CPU的最小單元###,執行緒都擁有各自的計數器、堆疊和局部變數等屬性, 並且能夠存取共享的記憶體變數。 CPU 在這些執行緒上高速切換,讓使用者感覺到這些執行緒同時執行(並發)。 #########執行緒上下切換:### 儲存上一個執行緒運行的中間狀態,執行下一個執行緒#################### ###序列:### 時間上不可重疊,前一個任務沒完成,下一個任務只能等待################並行:### 時間上是重疊的,兩個任務在同一時刻互不干擾的同時執行###############並發:### 運行兩個任務彼此幹擾,同一時間點,只有一個任務執行,交替執行#########

以上是Java底層作業系統與並發基礎有哪些的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

突破或從Java 8流返回? 突破或從Java 8流返回? Feb 07, 2025 pm 12:09 PM

Java 8引入了Stream API,提供了一種強大且表達力豐富的處理數據集合的方式。然而,使用Stream時,一個常見問題是:如何從forEach操作中中斷或返回? 傳統循環允許提前中斷或返回,但Stream的forEach方法並不直接支持這種方式。本文將解釋原因,並探討在Stream處理系統中實現提前終止的替代方法。 延伸閱讀: Java Stream API改進 理解Stream forEach forEach方法是一個終端操作,它對Stream中的每個元素執行一個操作。它的設計意圖是處

PHP:網絡開發的關鍵語言 PHP:網絡開發的關鍵語言 Apr 13, 2025 am 12:08 AM

PHP是一種廣泛應用於服務器端的腳本語言,特別適合web開發。 1.PHP可以嵌入HTML,處理HTTP請求和響應,支持多種數據庫。 2.PHP用於生成動態網頁內容,處理表單數據,訪問數據庫等,具有強大的社區支持和開源資源。 3.PHP是解釋型語言,執行過程包括詞法分析、語法分析、編譯和執行。 4.PHP可以與MySQL結合用於用戶註冊系統等高級應用。 5.調試PHP時,可使用error_reporting()和var_dump()等函數。 6.優化PHP代碼可通過緩存機制、優化數據庫查詢和使用內置函數。 7

PHP與Python:了解差異 PHP與Python:了解差異 Apr 11, 2025 am 12:15 AM

PHP和Python各有優勢,選擇應基於項目需求。 1.PHP適合web開發,語法簡單,執行效率高。 2.Python適用於數據科學和機器學習,語法簡潔,庫豐富。

PHP與其他語言:比較 PHP與其他語言:比較 Apr 13, 2025 am 12:19 AM

PHP適合web開發,特別是在快速開發和處理動態內容方面表現出色,但不擅長數據科學和企業級應用。與Python相比,PHP在web開發中更具優勢,但在數據科學領域不如Python;與Java相比,PHP在企業級應用中表現較差,但在web開發中更靈活;與JavaScript相比,PHP在後端開發中更簡潔,但在前端開發中不如JavaScript。

Java程序查找膠囊的體積 Java程序查找膠囊的體積 Feb 07, 2025 am 11:37 AM

膠囊是一種三維幾何圖形,由一個圓柱體和兩端各一個半球體組成。膠囊的體積可以通過將圓柱體的體積和兩端半球體的體積相加來計算。本教程將討論如何使用不同的方法在Java中計算給定膠囊的體積。 膠囊體積公式 膠囊體積的公式如下: 膠囊體積 = 圓柱體體積 兩個半球體體積 其中, r: 半球體的半徑。 h: 圓柱體的高度(不包括半球體)。 例子 1 輸入 半徑 = 5 單位 高度 = 10 單位 輸出 體積 = 1570.8 立方單位 解釋 使用公式計算體積: 體積 = π × r2 × h (4

PHP與Python:核心功能 PHP與Python:核心功能 Apr 13, 2025 am 12:16 AM

PHP和Python各有優勢,適合不同場景。 1.PHP適用於web開發,提供內置web服務器和豐富函數庫。 2.Python適合數據科學和機器學習,語法簡潔且有強大標準庫。選擇時應根據項目需求決定。

創造未來:零基礎的 Java 編程 創造未來:零基礎的 Java 編程 Oct 13, 2024 pm 01:32 PM

Java是熱門程式語言,適合初學者和經驗豐富的開發者學習。本教學從基礎概念出發,逐步深入解說進階主題。安裝Java開發工具包後,可透過建立簡單的「Hello,World!」程式來實踐程式設計。理解程式碼後,使用命令提示字元編譯並執行程序,控制台上將輸出「Hello,World!」。學習Java開啟了程式設計之旅,隨著掌握程度加深,可創建更複雜的應用程式。

PHP:許多網站的基礎 PHP:許多網站的基礎 Apr 13, 2025 am 12:07 AM

PHP成為許多網站首選技術棧的原因包括其易用性、強大社區支持和廣泛應用。 1)易於學習和使用,適合初學者。 2)擁有龐大的開發者社區,資源豐富。 3)廣泛應用於WordPress、Drupal等平台。 4)與Web服務器緊密集成,簡化開發部署。

See all articles