深入探究Java線程與進(jìn)程有哪些區(qū)別
一、進(jìn)程線和程的概念
線程: 一個(gè)線程是一個(gè)獨(dú)立的執(zhí)行流,每個(gè)線程之間都可以按照順訊執(zhí)行自己的代碼. 多個(gè)線程之間 “同時(shí)” 執(zhí)行著多份代碼
public class ThreadDemo { public static void main(String[] args) { Thread thread = new Thread(new Runnable() { @Override public void run() { //具體業(yè)務(wù) Thread thread1 = Thread.currentThread(); System.out.println("名稱(chēng):" + thread1.getName()); } }); //開(kāi)啟線程 thread.start(); } }
從以上代碼可以看出,每個(gè)線程都是一個(gè)獨(dú)立的執(zhí)行流
進(jìn)程:一個(gè)在內(nèi)存中運(yùn)行的應(yīng)用程序。每個(gè)進(jìn)程都有自己獨(dú)立的一塊內(nèi)存空間,一個(gè)進(jìn)程可以有多個(gè)線程,比如在Windows系統(tǒng)中,一個(gè)運(yùn)行的xx.exe就是一個(gè)進(jìn)程
二、為什么要有線程
(1)首先并發(fā)編程成為需求
當(dāng)單核CPU遇到問(wèn)題,還是會(huì)采用多核CPU,那么并發(fā)編程能更充分利用多核 CPU資源
(2)雖然進(jìn)程也可以并編程,但是線程更輕量
①創(chuàng)建線程比創(chuàng)建進(jìn)程更快.
②銷(xiāo)毀線程比銷(xiāo)毀進(jìn)程更快.
③調(diào)度線程比調(diào)度進(jìn)程更快.
(3)那么是不是線程創(chuàng)建越多越好
不是的,當(dāng)線程創(chuàng)建過(guò)多,會(huì)造成惡意爭(zhēng)搶和線程過(guò)度調(diào)度,返回時(shí)就會(huì)降低執(zhí)行效率
三、進(jìn)程和線程的關(guān)系
一個(gè)進(jìn)程中可以有多個(gè)線程,多個(gè)線程共享進(jìn)程的堆和方法區(qū) (JDK1.8 之后的元空間)資源,但是每個(gè)線程有自己的程序計(jì)數(shù)器、虛擬機(jī)棧 (線程私有)和 本地方法棧(線程私有)
什么是虛擬機(jī)棧,本地方法棧
(1)虛擬機(jī)棧:每個(gè) Java 方法在執(zhí)行的同時(shí)會(huì)創(chuàng)建一個(gè)棧幀用于存儲(chǔ)局部變量表、操作數(shù)棧、常量池引用等信息。從方法調(diào)用直至執(zhí)行完成的過(guò)程,就對(duì)應(yīng)著一個(gè)棧幀在 Java 虛擬機(jī)棧中入棧和出棧的過(guò)程。
(2)本地方法棧:和虛擬機(jī)棧所發(fā)揮的作用非常相似,區(qū)別是: 虛擬機(jī)棧為虛擬機(jī)執(zhí)行 Java 方法 (也就是字節(jié)碼)服務(wù),而本地方法棧則為虛擬機(jī)使用到的 Native 方法服務(wù)。 在 HotSpot 虛擬機(jī)中和 Java 虛擬機(jī)棧合二為一
四、線程和進(jìn)程的區(qū)別(重點(diǎn))
- 從屬關(guān)系上:線程屬于進(jìn)程,而對(duì)于進(jìn)程,則不屬于線程
- 共享方式:線程之間資源和地址空間是可以共享的,而進(jìn)程之間的地址空間和資源是相互獨(dú)立的
- 描述的側(cè)重點(diǎn):線程是操作系統(tǒng)調(diào)度的最小單位,進(jìn)程是系統(tǒng)分配資源的最小單位
- 上下切換的速度:線程是比較快的,而相對(duì)于進(jìn)程就比較慢
- 操作對(duì)象:進(jìn)程是操作系統(tǒng)操控,而線程是程序員可以用編碼操縱
五、用戶(hù)線程和守護(hù)線程區(qū)別
- Java程序的進(jìn)程里有幾個(gè)線程:主線程,垃圾回收線程(后臺(tái)線程),守護(hù)線程等,在main線程是默認(rèn)的非守護(hù)線程,也就是用戶(hù)線程
- 在用戶(hù)線程創(chuàng)建線程也是用戶(hù)線程
- 在守護(hù)線程下創(chuàng)建的子線程也是守護(hù)線程
關(guān)系:當(dāng)沒(méi)有用戶(hù)線程,那么守護(hù)線程也就沒(méi)存在必要了
區(qū)別:JVM不等待守護(hù)線程執(zhí)行完退出,JVM會(huì)等待用戶(hù)線程執(zhí)行完退出
到此這篇關(guān)于深入探究Java線程與進(jìn)程有哪些區(qū)別的文章就介紹到這了,更多相關(guān)Java線程與進(jìn)程內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
解讀java?try?catch?異常后還會(huì)繼續(xù)執(zhí)行嗎
這篇文章主要介紹了解讀java?try?catch?異常后還會(huì)不會(huì)繼續(xù)執(zhí)行問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11Java并發(fā)編程之關(guān)鍵字volatile知識(shí)總結(jié)
今天帶大家學(xué)習(xí)java的相關(guān)知識(shí),文章圍繞著Java關(guān)鍵字volatile展開(kāi),文中有非常詳細(xì)的知識(shí)總結(jié),需要的朋友可以參考下2021-06-06java.net.ConnectException: Connection refused問(wèn)題解決辦法
這篇文章主要介紹了java.net.ConnectException: Connection refused問(wèn)題解決辦法的相關(guān)資料,需要的朋友可以參考下2016-12-12簡(jiǎn)述Java中進(jìn)程與線程的關(guān)系_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
在 Java 語(yǔ)言中,對(duì)進(jìn)程和線程的封裝,分別提供了 Process 和 Thread 相關(guān)的一些類(lèi)。本文首先簡(jiǎn)單的介紹如何使用這些類(lèi)來(lái)創(chuàng)建進(jìn)程和線程2017-05-05如何通過(guò)RabbitMq實(shí)現(xiàn)動(dòng)態(tài)定時(shí)任務(wù)詳解
工作中經(jīng)常會(huì)有定時(shí)任務(wù)的需求,常見(jiàn)的做法可以使用Timer、Quartz、Hangfire等組件,這次想嘗試下新的思路,使用RabbitMQ死信隊(duì)列的機(jī)制來(lái)實(shí)現(xiàn)定時(shí)任務(wù),下面這篇文章主要給大家介紹了關(guān)于如何通過(guò)RabbitMq實(shí)現(xiàn)動(dòng)態(tài)定時(shí)任務(wù)的相關(guān)資料,需要的朋友可以參考下2022-01-01Spring Boot Admin 動(dòng)態(tài)修改日志級(jí)別的方法步驟
這篇文章主要介紹了Spring Boot Admin 動(dòng)態(tài)修改日志級(jí)別的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08