自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

面試官:談?wù)勀銓?duì)虛擬線程的理解?

開(kāi)發(fā) 前端
線程是輕量級(jí)的進(jìn)程,而虛擬線程則是輕量級(jí)的線程,虛擬線程是 JVM 層面實(shí)現(xiàn)的邏輯線程,不直接和操作系統(tǒng)的物理線程一一對(duì)應(yīng),因此使用它可以減少線程上下文切換所帶來(lái)的性能開(kāi)銷。
Java 中的虛擬線程,也叫做協(xié)程或“輕量級(jí)線程”,它誕生于 JDK 19(預(yù)覽 API),正式發(fā)布于 JDK 21,它是一種在 Java 虛擬機(jī)(JVM)層面實(shí)現(xiàn)的邏輯線程,不直接和操作系統(tǒng)的物理線程一一對(duì)應(yīng),因此它可以減少上下文切換所帶來(lái)的性能開(kāi)銷。

操作系統(tǒng)線程、普通線程(Java 線程)和虛擬線程的關(guān)系如下:圖片

虛擬線程使用

虛擬線程的創(chuàng)建方式,主要有以下 4 種:

  1. Thread.startVirtualThread(Runnable task)
  2. Thread.ofVirtual().unstarted(Runnable task)
  3. Thread.ofVirtual().factory()
  4. Executors.newVirtualThreadPerTaskExecutor()

具體示例如下。

1.startVirtualThread

創(chuàng)建虛擬線程,并直接啟動(dòng)執(zhí)行任務(wù):

// 創(chuàng)建并啟動(dòng)虛擬線程
Thread.startVirtualThread(() -> {
    System.out.println("Do virtual thread.");
});

2.unstarted

只創(chuàng)建虛擬線程,但不直接啟動(dòng):

// 創(chuàng)建虛擬線程
Thread vt = Thread.ofVirtual().unstarted(()->{
    System.out.println("Do virtual thread.");
});
// 運(yùn)行虛擬線程
vt.start();

3.factory

先創(chuàng)建虛擬線程工廠,然后再使用工廠創(chuàng)建虛擬線程,之后再調(diào)用 start() 方法進(jìn)行執(zhí)行:

// 創(chuàng)建虛擬線程工廠
ThreadFactory tf = Thread.ofVirtual().factory();
// 創(chuàng)建虛擬線程
Thread vt = tf.newThread(()->{
    System.out.println("Do virtual thread.");
});
// 運(yùn)行虛擬線程
vt.start();

4.newVirtualThreadPerTaskExecutor

使用線程池的方式創(chuàng)建虛擬線程:

// 創(chuàng)建一個(gè)支持虛擬線程的線程池
ExecutorService executor = Executors.newVirtualThreadPerTaskExecutor();
executor.submit(()->{
    System.out.println("Do virtual thread.");
});

虛擬線程 VS 普通線程

虛擬線程和普通線程的區(qū)別主要體現(xiàn)在以下幾點(diǎn):

  1. 普通線程是和操作系統(tǒng)的物理線程是一一對(duì)應(yīng)的,而虛擬線程是 JVM 層面的邏輯線程,并不和操作系統(tǒng)的物理線程一一對(duì)應(yīng),它可以看作是輕量級(jí)的線程。
  2. 普通線程默認(rèn)創(chuàng)建的是用戶線程(而守護(hù)線程),而虛擬線程是守護(hù)線程,并且其守護(hù)線程的屬性不能被修改,如果修改就會(huì)報(bào)錯(cuò),如下圖所示:

圖片

  1. 虛擬線程由 JVM 調(diào)度和使用,避免了普通線程頻繁切換的性能開(kāi)銷,所以相比于普通的線程來(lái)說(shuō),運(yùn)行效率更高。

小結(jié)

線程是輕量級(jí)的進(jìn)程,而虛擬線程則是輕量級(jí)的線程,虛擬線程是 JVM 層面實(shí)現(xiàn)的邏輯線程,不直接和操作系統(tǒng)的物理線程一一對(duì)應(yīng),因此使用它可以減少線程上下文切換所帶來(lái)的性能開(kāi)銷。它和普通線程的線程類型也不同,普通線程是默認(rèn)是用戶線程類型,而虛擬線程則是守護(hù)線程(而且不能被修改)。

責(zé)任編輯:武曉燕 來(lái)源: 磊哥和Java
相關(guān)推薦

2025-03-21 00:00:05

Reactor設(shè)計(jì)模式I/O 機(jī)制

2024-10-24 16:14:43

數(shù)據(jù)傳輸CPU零拷貝

2022-03-21 09:05:18

volatileCPUJava

2024-09-27 15:43:52

零拷貝DMAIO

2024-06-13 08:01:19

2024-08-27 12:36:33

2024-09-26 16:01:52

2024-08-26 14:52:58

JavaScript循環(huán)機(jī)制

2019-07-26 06:42:28

PG架構(gòu)數(shù)據(jù)庫(kù)

2024-10-12 16:25:12

2021-11-25 10:18:42

RESTfulJava互聯(lián)網(wǎng)

2021-08-09 07:47:40

Git面試版本

2025-01-13 09:24:32

2025-04-09 00:00:00

2024-08-23 09:02:56

2021-11-05 10:07:13

Redis哈希表存儲(chǔ)

2020-12-01 08:47:36

Java異常開(kāi)發(fā)

2020-06-12 15:50:56

options前端服務(wù)器

2020-06-19 15:32:56

HashMap面試代碼

2024-09-11 16:49:55

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)