Java多线程(7)--线程池创建线程
經(jīng)常創(chuàng)建和銷毀、使用量特別大的資源,比如并發(fā)情況下的線程,對性能影響很大。
提前創(chuàng)建好多個線程,放入線程池中,使用時直接獲取,使用完放回池中,可以避免頻繁創(chuàng)建銷毀、實現(xiàn)重復(fù)利用。
使用線程池好處:
①提高響應(yīng)速度(減少了創(chuàng)建新線程的時間)
②降低資源消耗(重復(fù)利用線程池中線程,不需要每次都創(chuàng)建)
③便于線程管理:corePoolSize:核心池的大小,maximumPoolSize:最大線程數(shù),keepAliveTime:線程沒有任務(wù)時最多保持多長時間后會終止
示例:
import java.util.concurrent.Callable; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.ThreadPoolExecutor;class NewThread implements Callable {private int sum;@Overridepublic Object call() throws Exception {for (int i = 0; i <= 100; i++) {if (i % 2 == 0){System.out.println(Thread.currentThread().getName() +":" + i);sum += i;}}return sum;} }class NewThread1 implements Runnable {private int sum;@Overridepublic void run() {for (int i = 0; i <= 100; i++) {if (i % 2 != 0) {System.out.println(Thread.currentThread().getName() + ":" + i);sum += i;}}} }public class NewThreadTest {public static void main(String[] args) {//提供指定數(shù)量的線程池,ExecutorService是接口,Executors是工具類ExecutorService service1 = Executors.newFixedThreadPool(10);//管理:需要先將service1強轉(zhuǎn)為ThreadPoolExecutor類對象,//ThreadPoolExecutor是ExecutorService接口的實現(xiàn)類ThreadPoolExecutor service = (ThreadPoolExecutor)service1;//service.方法去管理線程池//執(zhí)行,需要提供接口實現(xiàn)類對象service.submit(new NewThread()); //適用Callableservice.execute(new NewThread1()); //使用Runnable//關(guān)閉連接service.shutdown();} }Executors:工具類、線程池的工廠類,用于創(chuàng)建并返回不同類型的線程池
Executors.newCachedThreadPool():創(chuàng)建一個可根據(jù)需要創(chuàng)建新線程的線程池
Executors.newFixedThreadPool(n); 創(chuàng)建一個可重用固定線程數(shù)的線程池
Executors.newSingleThreadExecutor() :創(chuàng)建一個只有一個線程的線程池
Executors.newScheduledThreadPool(n):創(chuàng)建一個線程池,它可安排在給定延遲后運行命令或者定期地執(zhí)行
總結(jié)
以上是生活随笔為你收集整理的Java多线程(7)--线程池创建线程的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 自行招标备案时间(自行招标备案)
- 下一篇: Java常用类(1)--字符串相关类St