java四種線程池 java什么是線程池及為什么要使用線程池?
java什么是線程池及為什么要使用線程池?創(chuàng)建線程需要昂貴的資源和時(shí)間。如果一個(gè)任務(wù)來創(chuàng)建一個(gè)線程,響應(yīng)時(shí)間會(huì)更長,并且一個(gè)進(jìn)程可以創(chuàng)建的線程數(shù)是有限的。為了避免這些問題,當(dāng)程序啟動(dòng)時(shí),會(huì)創(chuàng)建幾個(gè)線程
java什么是線程池及為什么要使用線程池?
創(chuàng)建線程需要昂貴的資源和時(shí)間。如果一個(gè)任務(wù)來創(chuàng)建一個(gè)線程,響應(yīng)時(shí)間會(huì)更長,并且一個(gè)進(jìn)程可以創(chuàng)建的線程數(shù)是有限的。為了避免這些問題,當(dāng)程序啟動(dòng)時(shí),會(huì)創(chuàng)建幾個(gè)線程來響應(yīng)處理。它們稱為線程池,其中的線程稱為工作線程。從JDK1.5開始,javaapi提供了一個(gè)executor框架,允許您創(chuàng)建不同的線程池。例如,單個(gè)線程池,一次處理一個(gè)任務(wù);固定數(shù)量的線程池或緩存線程池(適用于許多短期任務(wù)的可擴(kuò)展線程池)。
java多線程ExecutorService線程數(shù)量?
添加了新的executors工廠類來生成線程池,例如以下方法
-public static executorservice newfixedthreadpool(int nthreads)
-public static executorservice這些方法的返回值是executorservice對象,它表示線程池,可以執(zhí)行由可運(yùn)行或可調(diào)用對象表示的線程。它提供以下方法:
-未來<?> submit(可運(yùn)行任務(wù))
-<T> future<T> submit(可調(diào)用<T>任務(wù))