Java多线程中线程池的简介说明
下文笔者讲述多线程的线程池的简介说明,如下所示:
创建线程池
线程池的用途
线程池: 用于存放多个线程的容器, 线程池中的线程可反复使用,可减少创建线程的操作,减少系统资源消耗 线程池的优点: 1.减少系统资源开销(由于采用池化技术,可使线程重复使用) 2.提高响应速度(直接从线程池中拿线程,所以速度快) 3.方便管理 可通过线程池的个数管理线程个数
创建线程池
创建线程池可采用以下方法: Executors 线程池执行器类 : 1. newCachedThreadPool(); 缓存数量线程池. 2. newFixedThreadPool(); 固定数量线程池. 3. newSingleThreadExecutor(); 单个可复用线程池对象. ExecutorService 执行器服务类 : 1. submit(Runnable task); 向线程池对象提交任务. 2. shutdown(); 关闭线程池对象.例:
创建线程池
package com.java265.other; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; public class XianChengChi { /** * java265.com 创建线程池 */ public static void main(String[] args) { // 创建要给线程池对象-5 ExecutorService threadPool = Executors.newFixedThreadPool(5); // 2. 向线程池对象中提交任务对象 for (int i = 0; i < 50; i++) { threadPool.submit(new Runnable() { @Override public void run() { // 随机耗时 ... try { Thread.sleep((long) (Math.random() * 500)); } catch (InterruptedException e) { e.printStackTrace(); } int sum = 0; for (int i = 1; i <= 100; i++) { sum += i; } System.out.println(Thread.currentThread().getName() + " 计算结果 = " + sum); } }); } // 3. 关闭线程池对象 threadPool.shutdown(); } }
版权声明
本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。