Java線程如何實現并不受Java虛擬機規范的約束,這是一個與具體虛擬機相關的話題。Java線程在 早期的Classic虛擬機上(JDK 1.2以前),是基于一種被稱為“綠色線程”(Green Threads)的用戶線程 實現的,但從JDK 1.3起,“主流”平臺上的“主流”商用Java虛擬機的線程模型普遍都被替換為基于操作 系統原生線程模型來實現,即采用1:1的線程模型
以HotSpot為例,它的每一個Java線程都是直接映射到一個操作系統原生線程來實現的,而且中間 沒有額外的間接結構,所以HotSpot自己是不會去干涉線程調度的(可以設置線程優先級給操作系統提 供調度建議),全權交給底下的操作系統去處理,所以何時凍結或喚醒線程、該給線程分配多少處理 器執行時間、該把線程安排給哪個處理器核心去執行等,都是由操作系統完成的,也都是由操作系統 全權決定的。
前面強調是兩個“主流”,那就說明肯定還有例外的情況,這里舉兩個比較著名的例子,一個是用 于Java ME的CLDC HotSpot Implementation(CLDC-HI,介紹可見第1章)。它同時支持兩種線程模 型,默認使用1:N由用戶線程實現的線程模型,所有Java線程都映射到一個內核線程上;不過它也可 以使用另一種特殊的混合模型,Java線程仍然全部映射到一個內核線程上,但當Java線程要執行一個阻 塞調用時,CLDC-HI會為該調用單獨開一個內核線程,并且調度執行其他Java線程,等到那個阻塞調 用完成之后再重新調度之前的Java線程繼續執行。
另外一個例子是在Solaris平臺的HotSpot虛擬機,由于操作系統的線程特性本來就可以同時支持 1:1(通過Bound Threads或Alternate Libthread實現)及N:M(通過LWP/Thread Based Synchronization 實現)的線程模型,因此Solaris版的HotSpot也對應提供了兩個平臺專有的虛擬機參數,即-XX: +UseLWPSynchronization(默認值)和-XX:+UseBoundThreads來明確指定虛擬機使用哪種線程模型
- 簡介
- 概述
- 進程vs線程
- 資源限制
- 有關并行的兩個定律
- 線程同步和阻塞
- 線程阻塞
- 線程的特性
- 守護線程
- 線程異常
- Thread
- 線程狀態
- 線程中斷
- wait¬ify
- suspend&resume
- join&yield
- notify¬ifyAll
- Thread.sleep
- 線程任務
- Runnable
- Callable
- Future模式
- FutureTask
- 線程實現方式
- 內核線程實現
- 用戶線程實現
- 混合實現
- Java線程的實現
- java與協程
- 纖程-Fiber
- 線程調度
- 多線程協作方式
- 阻塞
- 放棄
- 休眠
- 連接線程
- 線程估算公式
- 線程活躍性
- 死鎖
- 線程安全性
- 對象的發布與逸出
- 構造方法溢出
- 線程封閉
- 對象的可變性
- 原子性
- 原子操作
- CPU原子操作原理
- 總線鎖
- 緩存鎖
- JAVA如何實現原子操作
- long和double讀寫操作原子性
- Adder和Accumulator
- 線程性能
- 同步工具類
- 閉鎖
- CountDownLatch
- FutureTask
- 信號量
- 柵欄
- CyclicBarrier
- Exchanger
- 并發編程
- volatile
- synchronized
- 無鎖
- 偏向鎖
- 輕量級鎖
- 鎖的優缺點對比
- 鎖升級
- 鎖消除
- Monitor
- synchronized語法
- Mutex Lock
- synchronized實踐問題
- synchronized&ReentrantLock
- Lock
- ReentrantLock
- Condition
- 讀寫鎖
- ReadWriteLock
- StampedLock
- 線程池
- Executor
- ExecutorService
- Executors
- ThreadPoolExecutor
- RejectedExecutionHandler
- ThreadFactory
- 線程池大小公式
- 動態調整線程池大小
- Fork/Join框架
- ForkJoinPool
- CompletableFuture
- JUC并發工具包
- LockSupport
- 延時任務與周期任務
- Timer
- TimerTask
- 異構任務并行化
- CompletionService
- volatile和synchronized比較
- 鎖優化
- 鎖相關概念
- 悲觀鎖(排它鎖)
- 樂觀鎖
- 自旋鎖
- 樂觀鎖vs悲觀鎖
- JVM鎖優化-鎖消除
- ThreadLocal
- InheritableThreadLocal
- TransmittableThreadLocal
- ThreadLocalRandom
- 無鎖
- AtomicInteger
- Unsafe
- AtomicReference
- AtomicStampedReference
- AtomicIntegerArray
- AtomicIntegerFieldUpdater
- 無鎖Vector
- LongAdder
- LongAccumulator
- 常見鎖類型
- 悲觀鎖&獨占鎖
- 樂觀鎖
- 樂觀鎖vs悲觀鎖
- 自旋鎖vs適應性自旋鎖
- 公平鎖vs非公平鎖
- 可重入鎖vs非可重入鎖
- 獨享鎖vs共享鎖
- 互斥鎖
- CAS
- AQS介紹
- AQS深入剖析
- AQS框架
- AQS核心思想
- AQS數據結構
- 同步狀態State
- ReentrantLock vs AQS
- AQS與ReentrantLock的關聯
- ReentrantLock具體實現
- 線程加入等待隊列
- 等待隊列中線程出隊列時機
- 如何解鎖
- 中斷恢復后的執行流程
- ReentrantLock的可重入應用
- JUC中的應用場景
- 自定義同步工具
- CLH鎖
- 并發框架
- Akka
- Disruptor-無鎖緩存框架
- 常見面試題
- 兩個線程交替打印A和B
- 附錄