java線程池原理面試題及答案_第1頁(yè)
java線程池原理面試題及答案_第2頁(yè)
java線程池原理面試題及答案_第3頁(yè)
java線程池原理面試題及答案_第4頁(yè)
java線程池原理面試題及答案_第5頁(yè)
已閱讀5頁(yè),還剩7頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

java線程池原理面試題及答案

一、單項(xiàng)選擇題(每題2分,共20分)

1.Java中線程池的實(shí)現(xiàn)類是哪一個(gè)?

A.Thread

B.Runnable

C.ThreadPoolExecutor

D.ExecutorService

答案:C

2.線程池中哪個(gè)參數(shù)定義了線程池的最大線程數(shù)?

A.corePoolSize

B.maximumPoolSize

C.keepAliveTime

D.workQueueSize

答案:B

3.線程池中哪個(gè)參數(shù)定義了線程池中的線程在終止前可以空閑的時(shí)間?

A.corePoolSize

B.maximumPoolSize

C.keepAliveTime

D.workQueueSize

答案:C

4.線程池中哪個(gè)參數(shù)定義了線程池的工作隊(duì)列?

A.corePoolSize

B.maximumPoolSize

C.keepAliveTime

D.workQueue

答案:D

5.線程池中哪個(gè)參數(shù)定義了線程池的線程工廠?

A.threadFactory

B.handler

C.keepAliveTime

D.workQueue

答案:A

6.線程池中哪個(gè)參數(shù)定義了線程池飽和策略?

A.threadFactory

B.handler

C.keepAliveTime

D.workQueue

答案:B

7.當(dāng)線程池中的任務(wù)隊(duì)列滿了之后,線程池會(huì)如何處理新提交的任務(wù)?

A.直接拒絕

B.拋出異常

C.等待隊(duì)列可用

D.創(chuàng)建新線程

答案:A

8.線程池中的線程執(zhí)行完任務(wù)后,線程會(huì)如何?

A.銷毀

B.保持存活

C.進(jìn)入休眠狀態(tài)

D.被回收

答案:B

9.線程池中的線程是如何創(chuàng)建的?

A.直接使用new關(guān)鍵字創(chuàng)建

B.使用線程工廠創(chuàng)建

C.使用線程池內(nèi)部的默認(rèn)線程工廠創(chuàng)建

D.使用線程池的構(gòu)造函數(shù)創(chuàng)建

答案:B

10.線程池中的線程在執(zhí)行完任務(wù)后,線程池會(huì)如何處理這些線程?

A.銷毀

B.保持存活

C.進(jìn)入休眠狀態(tài)

D.被回收

答案:B

二、多項(xiàng)選擇題(每題2分,共20分)

1.線程池的狀態(tài)有哪些?

A.RUNNING

B.SHUTDOWN

C.STOP

D.TIDYING

E.TERMINATED

答案:ABCDE

2.線程池的飽和策略有哪些?

A.AbortPolicy

B.CallerRunsPolicy

C.DiscardPolicy

D.DiscardOldestPolicy

答案:ABCD

3.線程池的構(gòu)造方法中可以指定哪些參數(shù)?

A.corePoolSize

B.maximumPoolSize

C.keepAliveTime

D.workQueue

E.threadFactory

F.handler

答案:ABCDEF

4.線程池的哪些參數(shù)是必須指定的?

A.corePoolSize

B.maximumPoolSize

C.keepAliveTime

D.workQueue

E.threadFactory

F.handler

答案:AD

5.線程池中的哪些方法可以改變線程池的狀態(tài)?

A.shutdown()

B.shutdownNow()

C.start()

D.execute(Runnable)

答案:AB

6.線程池中的哪些方法可以用來(lái)提交任務(wù)?

A.execute(Runnable)

B.submit(Callable)

C.invokeAll(Iterable)

D.invokeAny(Callable)

答案:ABCD

7.線程池中的哪些方法可以獲取線程池的狀態(tài)?

A.isShutdown()

B.isTerminating()

C.isStopped()

D.awaitTermination(long,TimeUnit)

答案:ABCD

8.線程池中的哪些方法可以獲取線程池的參數(shù)?

A.getCorePoolSize()

B.getMaximumPoolSize()

C.getKeepAliveTime(TimeUnit)

D.getQueue()

答案:ABCD

9.線程池中的哪些方法可以設(shè)置線程池的參數(shù)?

A.setCorePoolSize(int)

B.setMaximumPoolSize(int)

C.setKeepAliveTime(long,TimeUnit)

D.setThreadFactory(ThreadFactory)

答案:ABCD

10.線程池中的哪些方法可以處理線程池的異常?

A.afterExecute(Runnable,Throwable)

B.beforeExecute(Thread,Runnable)

C.terminated()

D.uncaughtException(Thread,Throwable)

答案:AD

三、判斷題(每題2分,共20分)

1.線程池的corePoolSize參數(shù)可以設(shè)置為0。(對(duì))

2.線程池的maximumPoolSize參數(shù)必須大于等于corePoolSize。(對(duì))

3.線程池的keepAliveTime參數(shù)設(shè)置為0表示線程不會(huì)空閑。(錯(cuò))

4.線程池的工作隊(duì)列可以是無(wú)界的。(對(duì))

5.線程池的飽和策略不能自定義。(錯(cuò))

6.線程池的線程工廠可以自定義。(對(duì))

7.線程池的handler參數(shù)用于定義飽和策略。(對(duì))

8.線程池的線程執(zhí)行完任務(wù)后會(huì)被銷毀。(錯(cuò))

9.線程池的線程工廠創(chuàng)建的線程可以設(shè)置名稱。(對(duì))

10.線程池的線程執(zhí)行完任務(wù)后會(huì)進(jìn)入休眠狀態(tài)。(錯(cuò))

四、簡(jiǎn)答題(每題5分,共20分)

1.請(qǐng)簡(jiǎn)述線程池的工作原理。

答案:線程池工作原理是將任務(wù)提交給線程池后,線程池會(huì)根據(jù)當(dāng)前線程數(shù)量和任務(wù)隊(duì)列的情況來(lái)決定是直接執(zhí)行任務(wù)、將任務(wù)放入隊(duì)列等待執(zhí)行還是創(chuàng)建新線程來(lái)執(zhí)行任務(wù)。當(dāng)線程空閑時(shí),線程池會(huì)根據(jù)keepAliveTime參數(shù)來(lái)決定線程是否需要被銷毀。

2.線程池中的飽和策略有什么作用?

答案:線程池中的飽和策略用于處理當(dāng)線程池中所有線程都在忙碌且任務(wù)隊(duì)列已滿時(shí),新提交的任務(wù)應(yīng)該如何處理。不同的飽和策略有不同的處理方式,例如直接拒絕、由調(diào)用者線程執(zhí)行等。

3.線程池中的線程工廠有什么作用?

答案:線程池中的線程工廠用于創(chuàng)建新線程。通過(guò)自定義線程工廠,可以設(shè)置線程的名稱、優(yōu)先級(jí)等屬性,方便線程的管理和監(jiān)控。

4.線程池中的工作隊(duì)列有什么作用?

答案:線程池中的工作隊(duì)列用于存放待執(zhí)行的任務(wù)。當(dāng)線程池中的線程空閑時(shí),會(huì)從工作隊(duì)列中取出任務(wù)來(lái)執(zhí)行。工作隊(duì)列可以是有界的也可以是無(wú)界的,根據(jù)具體的業(yè)務(wù)需求來(lái)選擇。

五、討論題(每題5分,共20分)

1.討論線程池參數(shù)corePoolSize和maximumPoolSize的設(shè)置對(duì)系統(tǒng)性能的影響。

答案:corePoolSize和maximumPoolSize的設(shè)置直接影響線程池的并發(fā)能力和資源消耗。corePoolSize設(shè)置較小可能導(dǎo)致CPU資源浪費(fèi),而設(shè)置較大可能導(dǎo)致內(nèi)存資源緊張。maximumPoolSize設(shè)置較大可以提高系統(tǒng)的并發(fā)處理能力,但也會(huì)增加系統(tǒng)的資源消耗。

2.討論線程池的飽和策略對(duì)系統(tǒng)的影響。

答案:線程池的飽和策略對(duì)系統(tǒng)的影響主要體現(xiàn)在任務(wù)處理的及時(shí)性和系統(tǒng)的穩(wěn)定性上。不同的飽和策略會(huì)導(dǎo)致不同的任務(wù)處理方式,可能會(huì)影響系統(tǒng)的響應(yīng)時(shí)間和資源利用率。

3.討論線程池的線程工廠和工作隊(duì)列的自定義對(duì)系統(tǒng)的影響。

答案:線程池的線程工廠和工作隊(duì)列的自定義可以提高系統(tǒng)的靈活性和可維護(hù)性。通過(guò)自定義線程工廠,可以設(shè)置線

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論