搜尋
首頁Javajava教程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刪除
JVM中的類加載程序子系統如何促進平台獨立性?JVM中的類加載程序子系統如何促進平台獨立性?Apr 23, 2025 am 12:14 AM

類加載器通過統一的類文件格式、動態加載、雙親委派模型和平台無關的字節碼,確保Java程序在不同平台上的一致性和兼容性,實現平台獨立性。

Java編譯器會產生特定於平台的代碼嗎?解釋。Java編譯器會產生特定於平台的代碼嗎?解釋。Apr 23, 2025 am 12:09 AM

Java編譯器生成的代碼是平台無關的,但最終執行的代碼是平台特定的。 1.Java源代碼編譯成平台無關的字節碼。 2.JVM將字節碼轉換為特定平台的機器碼,確保跨平台運行但性能可能不同。

JVM如何處理不同操作系統的多線程?JVM如何處理不同操作系統的多線程?Apr 23, 2025 am 12:07 AM

多線程在現代編程中重要,因為它能提高程序的響應性和資源利用率,並處理複雜的並發任務。 JVM通過線程映射、調度機制和同步鎖機制,在不同操作系統上確保多線程的一致性和高效性。

在Java的背景下,'平台獨立性”意味著什麼?在Java的背景下,'平台獨立性”意味著什麼?Apr 23, 2025 am 12:05 AM

Java的平台獨立性是指編寫的代碼可以在任何安裝了JVM的平台上運行,無需修改。 1)Java源代碼編譯成字節碼,2)字節碼由JVM解釋執行,3)JVM提供內存管理和垃圾回收功能,確保程序在不同操作系統上運行。

Java應用程序仍然可以遇到平台特定的錯誤或問題嗎?Java應用程序仍然可以遇到平台特定的錯誤或問題嗎?Apr 23, 2025 am 12:03 AM

Javaapplicationscanindeedencounterplatform-specificissuesdespitetheJVM'sabstraction.Reasonsinclude:1)Nativecodeandlibraries,2)Operatingsystemdifferences,3)JVMimplementationvariations,and4)Hardwaredependencies.Tomitigatethese,developersshould:1)Conduc

雲計算如何影響Java平台獨立性的重要性?雲計算如何影響Java平台獨立性的重要性?Apr 22, 2025 pm 07:05 PM

云计算显著提升了Java的平台独立性。1)Java代码编译为字节码,由JVM在不同操作系统上执行,确保跨平台运行。2)使用Docker和Kubernetes部署Java应用,提高可移植性和可扩展性。

Java的平台獨立性在廣泛採用中扮演著什麼角色?Java的平台獨立性在廣泛採用中扮演著什麼角色?Apr 22, 2025 pm 06:53 PM

Java'splatformindependenceallowsdeveloperstowritecodeonceandrunitonanydeviceorOSwithaJVM.Thisisachievedthroughcompilingtobytecode,whichtheJVMinterpretsorcompilesatruntime.ThisfeaturehassignificantlyboostedJava'sadoptionduetocross-platformdeployment,s

容器化技術(例如Docker)如何影響Java平台獨立性的重要性?容器化技術(例如Docker)如何影響Java平台獨立性的重要性?Apr 22, 2025 pm 06:49 PM

容器化技術如Docker增強而非替代Java的平台獨立性。 1)確保跨環境的一致性,2)管理依賴性,包括特定JVM版本,3)簡化部署過程,使Java應用更具適應性和易管理性。

See all articles

熱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

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

熱工具

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),