日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > java >内容正文

java

【Java 并发编程】线程简介 ( 进程与线程 | 并发概念 | 线程间通信 | Java 并发 3 特性 )

發(fā)布時間:2025/6/17 java 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【Java 并发编程】线程简介 ( 进程与线程 | 并发概念 | 线程间通信 | Java 并发 3 特性 ) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

文章目錄

  • 一、進(jìn)程與線程
  • 二、并發(fā)
  • 三、線程間通信
  • 四、Java 并發(fā) 3 特性





一、進(jìn)程與線程



最開始是沒有線程這個概念的 , 一個應(yīng)用程序就是一個進(jìn)程 , 應(yīng)用程序運(yùn)行時 , 如果還要處理與用戶交互的邏輯 , 二者只能 交替進(jìn)行 , 這樣 CPU 執(zhí)行效率就很低 ;

CPU 是整個計算機(jī)系統(tǒng)中的 稀缺資源 , 程序的運(yùn)行 , 計算 都需要依賴 CPU 完成 ;

為了 高效利用 CPU 這個稀缺資源 , 引入了線程概念 ;


進(jìn)程 : 每個應(yīng)用都是一個獨(dú)立進(jìn)程 , 是 資源分配 , 調(diào)度 的最小單元 ;

線程 : CPU 調(diào)度的最小單元 ;





二、并發(fā)



CPU 是多核的 ;

進(jìn)程 是在 物理內(nèi)存 中執(zhí)行的 ( 內(nèi)存條 或 RAM ) ;

每個進(jìn)程 中 有若干 線程 ;

CPU 運(yùn)行線程時 , 通過 OS 線程調(diào)度 , 在 某個 CPU某個 核 上 執(zhí)行 某個 進(jìn)程某個 線程 ;

程序的執(zhí)行 , 最終是靠指令進(jìn)行執(zhí)行 ;

進(jìn)程 在 內(nèi)存中 , 會被劃分一塊 獨(dú)立的區(qū)域 , 每個進(jìn)程之間的內(nèi)存都是 隔離 的 , 一個進(jìn)程的崩潰 , 不會影響其它進(jìn)程 ;

每個線程執(zhí)行時 , JVM 都會為該線程單獨(dú)分配 線程棧 , 本地方法棧 , 程序計數(shù)器 , 三者都是線程獨(dú)有的數(shù)據(jù) ;

程序運(yùn)行 的 指令 , 就放在 上面的 線程棧 中 ;

每個 線程棧 中都有 一串指令 , 等待執(zhí)行 ;

這些線程棧 , 不能 串行 執(zhí)行 , 必須 并發(fā) 執(zhí)行 , 才能保證所有的應(yīng)用程序 , 都能得到很好的用戶體驗 ;

并行 是 同一個 時間點 處理多個事件 ;
并發(fā) 是 同一個 時間段 處理多個事件 ;





三、線程間通信



線程間通信 :

假設(shè)有 222 個線程 A 和 B ;

線程一旦執(zhí)行后 , 會在內(nèi)存中分配 線程棧 , 該線程棧中有一塊 本地內(nèi)存 ;

有一些對象是共享的 , 所有線程都可以訪問 , 如 堆內(nèi)存 , 在 線程棧 中的 本地內(nèi)存 中 , 有一個 共享變量的副本 ;


在 主內(nèi)存 中 , 有很多 共享變量 ;

主內(nèi)存中有變量 int a = 1 , 如果線程 A 中想要訪問變量 a , 就會將該變量 int a = 1 變量 復(fù)制到 線程 A 的 本地內(nèi)存中 ;

如果線程 B 也想訪問 , 則將該變量 int a = 1 變量 復(fù)制到 線程 B 的 本地內(nèi)存中 ;


如果在 線程 A 中 , 對變量 a 進(jìn)行 +1 操作 , 只是對 線程 A 本地內(nèi)存 中的 變量 a 副本進(jìn)行了 +1 操作 , 主內(nèi)存線程 B 中的 a 變量 沒有變化 ;

假如 線程 A 和 線程 B 同時對 本地內(nèi)存 中的變量 a 進(jìn)行操作 , 那么就有可能出現(xiàn) a 取值異常的情況 ;


主內(nèi)存 中的數(shù)據(jù) , 對所有的線程都可見 ; 但是 線程 A 和 線程 B 之間 , 互相不知道對方線程 本地內(nèi)存 中的數(shù)據(jù) ;

這種情況就是線程不安全的情況 ;





四、Java 并發(fā) 3 特性



Java 并發(fā)的 333 特性 :

  • 原子性 : 每個操作都是 不可拆分的原子操作 ; 在線程中進(jìn)行 a++ 就不是原子操作 , 該操作分為 333 個步驟 , 首先從主內(nèi)存中讀取 a 變量 , 然后進(jìn)行自增操作 , 最后在將自增后的值寫回主內(nèi)存中 ;
  • 可見性 : 多個線程 訪問同一個變量 , 該變量一旦被 某個線程修改 , 這些線程必須可以 立刻看到被修改的值 ;
  • 有序性 : 程序按照 代碼先后順序 執(zhí)行 ;

總結(jié)

以上是生活随笔為你收集整理的【Java 并发编程】线程简介 ( 进程与线程 | 并发概念 | 线程间通信 | Java 并发 3 特性 )的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。