Java多线程(7)--线程池创建线程
生活随笔
收集整理的這篇文章主要介紹了
Java多线程(7)--线程池创建线程
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
經常創建和銷毀、使用量特別大的資源,比如并發情況下的線程,對性能影響很大。
提前創建好多個線程,放入線程池中,使用時直接獲取,使用完放回池中,可以避免頻繁創建銷毀、實現重復利用。
使用線程池好處:
①提高響應速度(減少了創建新線程的時間)
②降低資源消耗(重復利用線程池中線程,不需要每次都創建)
③便于線程管理:corePoolSize:核心池的大小,maximumPoolSize:最大線程數,keepAliveTime:線程沒有任務時最多保持多長時間后會終止
示例:
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) {//提供指定數量的線程池,ExecutorService是接口,Executors是工具類ExecutorService service1 = Executors.newFixedThreadPool(10);//管理:需要先將service1強轉為ThreadPoolExecutor類對象,//ThreadPoolExecutor是ExecutorService接口的實現類ThreadPoolExecutor service = (ThreadPoolExecutor)service1;//service.方法去管理線程池//執行,需要提供接口實現類對象service.submit(new NewThread()); //適用Callableservice.execute(new NewThread1()); //使用Runnable//關閉連接service.shutdown();} }Executors:工具類、線程池的工廠類,用于創建并返回不同類型的線程池
Executors.newCachedThreadPool():創建一個可根據需要創建新線程的線程池
Executors.newFixedThreadPool(n); 創建一個可重用固定線程數的線程池
Executors.newSingleThreadExecutor() :創建一個只有一個線程的線程池
Executors.newScheduledThreadPool(n):創建一個線程池,它可安排在給定延遲后運行命令或者定期地執行
總結
以上是生活随笔為你收集整理的Java多线程(7)--线程池创建线程的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 自行招标备案时间(自行招标备案)
- 下一篇: Java常用类(1)--字符串相关类St