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