大战熟女丰满人妻av-荡女精品导航-岛国aaaa级午夜福利片-岛国av动作片在线观看-岛国av无码免费无禁网站-岛国大片激情做爰视频

專注Java教育14年 全國咨詢/投訴熱線:400-8080-105
動力節點LOGO圖
始于2009,口口相傳的Java黃埔軍校
首頁 學習攻略 職業指南 大廠級別的多線程面試題

大廠級別的多線程面試題

更新時間:2022-12-21 15:36:22 來源:動力節點 瀏覽1242次

1、什么是線程和進程?

進程:在操作系統中能夠獨立運行,并且作為資源分配的基本單位。它表示運行中的程序。系統運行一個程序就是一個進程從創建、運行到消亡的過程。

線程:是一個比進程更小的執行單位,能夠完成進程中的一個功能,也被稱為輕量級進程。一個進程在其執行的過程中可以產生多個線程。

【注】線程與進程不同的是:同類的多個線程共享進程的堆和方法區資源,但每個線程有自己的程序計數器、虛擬機棧和本地方法棧,所以系統在產生一個線程,或是在各個線程之間作切換工作時,負擔要比進程小得多。

多線程面試題

為什么程序計數器、虛擬機棧和本地方法棧是線程私有的呢?為什么堆和方法區是線程共享的呢?

  • 程序計數器為什么是私有的?

程序計數器主要有下面兩個作用:

字節碼解釋器通過改變程序計數器來依次讀取指令,從而實現代碼的流程控制,如:順序執行、選擇、循環、異常處理。

在多線程的情況下,程序計數器用于記錄當前線程執行的位置,從而當線程被切換回來的時候能夠知道該線程上次運行到哪兒了。

(需要注意的是,如果執行的是 native 方法,那么程序計數器記錄的是 undefined 地址,只有執行的是 Java 代碼時程序計數器記錄的才是下一條指令的地址。)

所以,程序計數器私有主要是為了線程切換后能恢復到正確的執行位置。

  • 虛擬機棧和本地方法棧為什么是私有的?

虛擬機棧: 每個 Java 方法在執行的同時會創建一個棧幀用于存儲局部變量表、操作數棧、常量池引用等信息。從方法調用直至執行完成的過程,就對應著一個棧幀在 Java 虛擬機棧中入棧和出棧的過程。

本地方法棧: 和虛擬機棧所發揮的作用非常相似,區別是: 虛擬機棧為虛擬機執行 Java 方法 (也就是字節碼)服務,而本地方法棧則為虛擬機使用到的 Native 方法服務。 在 HotSpot 虛擬機中和 Java 虛擬機棧合二為一。

所以,為了保證線程中的局部變量不被別的線程訪問到,虛擬機棧和本地方法棧是線程私有的。

堆和方法區是所有線程共享的資源,其中:

堆是進程中最大的一塊內存,主要用于存放新創建的對象 (所有對象都在這里分配內存)。

方法區主要用于存放已被加載的類信息、常量、靜態變量、即時編譯器編譯后的代碼等數據。

2、什么是上下文切換?

即使單核處理器也支持多線程執行代碼,CPU通過給每個線程分配CPU時間片來實現這個機制。時間片是CPU分配給各個線程的時間,因為時間片非常短,所以CPU通過不停地切換線程執行,讓我們感覺多個線程是同時執行的。(時間片一般是幾十毫秒)

CPU通過時間片分配算法來循環執行任務,當前任務執行一個時間片后會切換到下一個任務。但是,在切換前會保存上一個任務的狀態,以便下次切換回這個任務時,可以再加載這個任務的狀態。所以任務從保存到加載的過程就是一次上下文切換。上下文切換會影響多線程的執行速度。

3、并發與并行?

并發指的是多個任務交替進行,并行則是指真正意義上的“同時進行”。

實際上,如果系統內只有一個CPU,使用多線程時,在真實系統環境下不能并行,只能通過切換時間片的方式交替進行,從而并發執行任務。真正的并行只能出現在擁有多個CPU的系統中。

4、線程的生命周期和狀態?(重要!)

Java 線程在運行的生命周期中的指定時刻只可能處于下面 6 種不同狀態的其中一個狀態:

初始狀態、運行狀態、阻塞狀態、等待狀態、超時等待狀態、終止狀態

多線程面試題

線程在生命周期中并不是固定處于某一個狀態而是隨著代碼的執行在不同狀態之間切換:

多線程面試題

  • 線程創建之后它將處于 初始狀態(NEW),調用 start() 方法后開始運行,線程這時候處于 可運行狀態(READY)。
  • 可運行狀態的線程獲得了 CPU 時間片后就處于 運行狀態(RUNNING)。
  • 當線程執行 wait()方法之后,線程進入 等待狀態(WAITING),進入等待狀態的線程需要依靠其他線程的通知才能夠返回到運行狀態【notify()】。 而 超時等待狀態(TIME_WAITING)相當于在等待狀態的基礎上增加了超時限制,【sleep(long millis)/wait(long millis)】,當超時時間到達后 Java 線程將會返回到運行狀態。
  • 當線程調用同步方法時,在沒有獲取到鎖的情況下,線程將會進入到阻塞狀態(BLOCKED)。
  • 線程在執行 Runnable 的run()方法之后將會進入到 終止狀態(TERMINATED)。

5、什么是線程死鎖?如何避免死鎖?

多個線程同時被阻塞,它們中的一個或者全部都在等待某個資源被釋放。由于線程被無限期地阻塞,因此程序不可能正常終止。

假如線程 A 持有資源 2,線程 B 持有資源 1,他們同時都想申請對方的資源,所以這兩個線程就會互相等待而進入死鎖狀態。

避免死鎖的幾個常見方法:

  • 避免一個線程同時獲取多個鎖
  • 避免一個線程在鎖內同時占用多個資源,盡量保證每個鎖只占用一個資源。
  • 嘗試使用定時鎖,使用 lock.tryLock(timeout) 來代替使用內部鎖機制。
  • 對于數據庫鎖,加鎖和解鎖必須在一個數據庫連接里,否則會出現解鎖失敗的情況。

 以上就是“大廠級別的多線程面試題”,你能回答上來嗎?如果想要了解更多的Java面試題相關內容,可以關注動力節點Java官網。

提交申請后,顧問老師會電話與您溝通安排學習

免費課程推薦 >>
技術文檔推薦 >>
主站蜘蛛池模板: 色狠狠成人综合网 | 尤物视频在线观看视频 | 中文字幕精品一区二区三区在线 | 午夜看一级特黄a大片黑 | 国内视频自拍在线视频 | 福利在线看 | 欧美日韩你懂的 | 老司机午夜免费影院 | 乱子伦免费视频中文字幕 | 黑人和黑人激情一级毛片 | 香蕉成人国产精品免费看网站 | 色八戒国产一区二区三区四区 | 色一色综合 | 五月婷婷欧美 | 亚洲综合色网站 | 久久综合精品不卡一区二区 | 国产女人又爽又大 | 欧美中文字幕在线观看 | 国内精品久久久久久久久久久久 | 日日日日干 | 在线亚洲精品国产成人二区 | 天天草夜夜骑 | 久久天天躁狠狠躁夜夜不卡 | 国产女人久久精品 | 国内视频自拍在线视频 | 特黄特黄aaaa级毛片免费看 | 久久午夜精品 | 成人亚洲欧美日韩中文字幕 | 久久精品国内一区二区三区 | 殴美毛片 | 亚洲欧洲一区二区三区久久 | 五月天在线婷婷 | 四虎影视精品 | 国产美女流白浆的免费视 | 欧美精品亚洲人成在线观看 | 国产一区二区三区亚洲综合 | 日本大臿亚洲香蕉大片 | 亚洲国产二区 | 最新亚洲情黄在线网站 | 欧美日韩中文国产一区二区三区 | 久久精品国产日本波多麻结衣 |