java多線程編程實(shí)例 什么是線程調(diào)度器(ThreadScheduler)和時(shí)間分片(TimeSlicing)?
什么是線程調(diào)度器(ThreadScheduler)和時(shí)間分片(TimeSlicing)?線程調(diào)度程序是一種操作系統(tǒng)服務(wù),負(fù)責(zé)將CPU時(shí)間分配給處于可運(yùn)行狀態(tài)的線程。一旦線程被創(chuàng)建和啟動(dòng),它的執(zhí)行就取決
什么是線程調(diào)度器(ThreadScheduler)和時(shí)間分片(TimeSlicing)?
線程調(diào)度程序是一種操作系統(tǒng)服務(wù),負(fù)責(zé)將CPU時(shí)間分配給處于可運(yùn)行狀態(tài)的線程。一旦線程被創(chuàng)建和啟動(dòng),它的執(zhí)行就取決于線程調(diào)度程序的實(shí)現(xiàn)。時(shí)間切片是將可用的CPU時(shí)間分配給可用的可運(yùn)行線程的過程。CPU時(shí)間的分配可以基于線程優(yōu)先級(jí)或線程等待時(shí)間。線程調(diào)度不是由Java虛擬機(jī)控制的,所以最好由應(yīng)用程序控制(也就是說,不要讓應(yīng)用程序依賴于線程的優(yōu)先級(jí))。
線程調(diào)度的簡(jiǎn)介?
有兩種調(diào)度模型:分時(shí)調(diào)度模型和搶占式調(diào)度模型。分時(shí)調(diào)度模型是讓所有線程依次獲得CPU的使用權(quán),并平均分配每個(gè)線程占用的CPU時(shí)間片。這也很容易理解。Java虛擬機(jī)采用搶占式調(diào)度模型,即對(duì)可運(yùn)行池中優(yōu)先級(jí)較高的線程優(yōu)先占用CPU。如果可運(yùn)行池中的線程具有相同的優(yōu)先級(jí),則隨機(jī)選擇一個(gè)線程來占用CPU。正在運(yùn)行的線程一直運(yùn)行到必須放棄CPU為止。
對(duì)于多核CPU java中Thread.currentThread() 指的是哪個(gè)核上的線程?
Java線程類庫(kù)不提供任何獲取CPU核心信息的API。
如上圖所示,Java使用操作系統(tǒng)的輕量級(jí)進(jìn)程接口實(shí)現(xiàn)線程,輕量級(jí)進(jìn)程與內(nèi)核線程一一對(duì)應(yīng)。內(nèi)核線程由操作系統(tǒng)調(diào)度并分配給CPU內(nèi)核執(zhí)行。換句話說,Java虛擬機(jī)不直接調(diào)用CPU,而是將任務(wù)提交給操作系統(tǒng),由CPU的內(nèi)核執(zhí)行線程。
在大多數(shù)情況下,Java程序不需要關(guān)心線程由哪個(gè)CPU核心執(zhí)行,因?yàn)镴ava程序不會(huì)對(duì)操作系統(tǒng)的線程調(diào)度產(chǎn)生任何影響,除非使用JNI調(diào)用一些底層操作。在這種情況下,不能使用Java自己的線程類庫(kù)來檢查問題。
多核cpu是怎么線程調(diào)度的?
首先,感謝您的邀請(qǐng),希望能得到很好的答復(fù)。如果你認(rèn)為答案是可以的,請(qǐng)注意我,嘿嘿…
計(jì)算機(jī)CPU和多線程
進(jìn)程和線程:一個(gè)進(jìn)程包含線程,一個(gè)進(jìn)程包含多個(gè)線程。線程是CPU調(diào)度和分配的基本單元,進(jìn)程是操作系統(tǒng)單元分配的最小資源(CPU、內(nèi)存、硬盤IO等)。
單核CPU:多進(jìn)程的實(shí)現(xiàn)取決于操作系統(tǒng)的進(jìn)程調(diào)度算法,如時(shí)間片旋轉(zhuǎn)算法。例如,有三個(gè)正在運(yùn)行的程序(即三個(gè)進(jìn)程)。操作系統(tǒng)會(huì)讓單核CPU依次運(yùn)行這些進(jìn)程,然后一個(gè)進(jìn)程只運(yùn)行2ms,看起來是多個(gè)進(jìn)程同時(shí)運(yùn)行,從而實(shí)現(xiàn)多進(jìn)程
多線程實(shí)際上是最重要的任務(wù),充分利用CPU資源。具有兩個(gè)線程的進(jìn)程的執(zhí)行時(shí)間可能比具有一個(gè)線程的進(jìn)程的執(zhí)行時(shí)間長(zhǎng)兩倍,因?yàn)榫€程切換也需要時(shí)間。也就是說,多線程可能不會(huì)提高程序的運(yùn)行速度,反而會(huì)降低速度,但是對(duì)于用戶來說,它能減少用戶核心CPU的響應(yīng)時(shí)間嗎?多核CPU是一種集成了多個(gè)完整計(jì)算引擎(核心)的處理器
多核CPU和單核CPU對(duì)于進(jìn)程是并行的,而不是并行的
但是多核CPU的每個(gè)核心可以獨(dú)立執(zhí)行一個(gè)線程,所以多核CPU可以真正實(shí)現(xiàn)多線程并行。例如,四核CPU可以將線程1234分配給核1234,如果有線程567,則最好等待CPU調(diào)度。螺紋1234平行。如果核心1停止執(zhí)行,線程1變?yōu)榫€程5,那么線程15是并發(fā)的。
Java多線程
JVM多線程和多核cpu:java多線程機(jī)制允許多個(gè)任務(wù)同時(shí)執(zhí)行,所有線程共享JVM內(nèi)存區(qū)主存,每個(gè)線程都有自己的工作內(nèi)存。當(dāng)線程與內(nèi)存區(qū)交互時(shí),數(shù)據(jù)從主存拷貝到工作內(nèi)存,然后由線程(操作碼和操作數(shù))進(jìn)行處理,通過線程輪流切換和分配處理器的執(zhí)行時(shí)間的方式實(shí)現(xiàn)虛擬機(jī)的多線程處理。在任何給定的時(shí)間,處理器(多核處理器的內(nèi)核)只會(huì)在一個(gè)線程中執(zhí)行指令。因此,在多核CPU的情況下,將在多核上調(diào)度多個(gè)線程