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