欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

深入探究Java線程與進程有哪些區(qū)別

 更新時間:2022年04月26日 10:21:59   作者:淡沫初夏Zz  
這篇文章主要介紹了Java并發(fā)編程之線程創(chuàng)建,進程是代碼在數(shù)據(jù)集合上的一次運行活動,是系統(tǒng)進行資源分配和調度的基本單位,線程則是一個實體,一個進程中至少有一個線程,下文更多相關內容需要的小伙伴可以參考一下

一、進程線和程的概念

線程: 一個線程是一個獨立的執(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中異常傳播的實現(xiàn)

    Java中異常傳播的實現(xiàn)

    在Java中,異常傳播是一個重要的概念,本文主要介紹了Java中異常傳播的實現(xiàn),具有一定的參考價值,感興趣的可以了解一下
    2024-01-01
  • 解讀java?try?catch?異常后還會繼續(xù)執(zhí)行嗎

    解讀java?try?catch?異常后還會繼續(xù)執(zhí)行嗎

    這篇文章主要介紹了解讀java?try?catch?異常后還會不會繼續(xù)執(zhí)行問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • Java多線程與線程池技術分享

    Java多線程與線程池技術分享

    這篇文章主要介紹了Java多線程與線程池技術分享,線程池本質是池化技術的應用,和連接池類似,創(chuàng)建連接與關閉連接屬于耗時操作,下文相關介紹需要的小伙伴可以參考一下
    2022-03-03
  • Java并發(fā)編程之關鍵字volatile知識總結

    Java并發(fā)編程之關鍵字volatile知識總結

    今天帶大家學習java的相關知識,文章圍繞著Java關鍵字volatile展開,文中有非常詳細的知識總結,需要的朋友可以參考下
    2021-06-06
  • java.net.ConnectException: Connection refused問題解決辦法

    java.net.ConnectException: Connection refused問題解決辦法

    這篇文章主要介紹了java.net.ConnectException: Connection refused問題解決辦法的相關資料,需要的朋友可以參考下
    2016-12-12
  • 簡述Java中進程與線程的關系_動力節(jié)點Java學院整理

    簡述Java中進程與線程的關系_動力節(jié)點Java學院整理

    在 Java 語言中,對進程和線程的封裝,分別提供了 Process 和 Thread 相關的一些類。本文首先簡單的介紹如何使用這些類來創(chuàng)建進程和線程
    2017-05-05
  • 比較排序之快速排序(實例代碼)

    比較排序之快速排序(實例代碼)

    下面小編就為大家?guī)硪黄容^排序之快速排序(實例代碼)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • 如何通過RabbitMq實現(xiàn)動態(tài)定時任務詳解

    如何通過RabbitMq實現(xiàn)動態(tài)定時任務詳解

    工作中經(jīng)常會有定時任務的需求,常見的做法可以使用Timer、Quartz、Hangfire等組件,這次想嘗試下新的思路,使用RabbitMQ死信隊列的機制來實現(xiàn)定時任務,下面這篇文章主要給大家介紹了關于如何通過RabbitMq實現(xiàn)動態(tài)定時任務的相關資料,需要的朋友可以參考下
    2022-01-01
  • Java如何分析算法的時間和空間復雜度

    Java如何分析算法的時間和空間復雜度

    這篇文章主要介紹了Java如何分析算法的時間和空間復雜度,在計算機科學中,計算復雜性解釋了算法的性能。文章圍繞主題展開詳細的內容介紹,具有一定的參考價值,需要的朋友可以參考一下
    2022-06-06
  • Spring Boot Admin 動態(tài)修改日志級別的方法步驟

    Spring Boot Admin 動態(tài)修改日志級別的方法步驟

    這篇文章主要介紹了Spring Boot Admin 動態(tài)修改日志級別的方法步驟,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-08-08

最新評論