Java线程-连接池一(连接池概念&自定义连接池)

本文介绍了Java线程池的概念,解释了为何使用线程池以提高系统效率和响应速度。线程池适用于并发场景,如秒杀系统、文件上传下载等。通过分析线程池参数,如核心线程数、任务队列长度和最大线程数,指导如何自定义线程池,并提供了简单的实现步骤和代码示例。
摘要由CSDN通过智能技术生成

Java线程池简介

Java多线程相关的内容,我分为几个章节分别介绍。
其中 Thread、Runnable、Callable创建线程为Java的线程基础,我作为第一节记述,后续是线程池的相关知识,循序渐进的阐述。
最后是一些线程方面的面试题,争取做到包含大厂和一些基础知识的面试题涵盖。

什么是线程池

线程池其实就是一种多线程的处理方式,处理过程中可以将任务添加到队列中,然后在创建线程后自动启动这些任务。
(这里的任务就是实现的Runnable或Callable接口的实例对象)

为什么使用线程池

使用线程池最大的原因就是可以根据系统需求和硬件环境灵活的控制线程的数量,且可以对所有线程进行统一的管理和控制,从而提高系统的运行效率,降低系统运行压力。

优势:
1. 线程和任务分离,提升线程的重要性;
2. 控制线程并发数量,降低服务器压力,统一管理所有线程。
3. 提升系统响应速度,假如创建线程的时间t1,执行任务时间t2,撤销任务时间t3,那么使用线程池就免去了t1和t3的时间。

线程池的应用场景

应用场景介绍
1.团购商品秒杀;
2.云盘文件上传下载;
3.12306网上购票系统
总之
只要有并发的地方、任务数量大或小、每个执行的时间长或短都可以使用线程池;只不过在使用线程池的时候,注意一下设置合理的线程池大小。

线程池的使用

1.自定义线程池

首先了解一下Java关于线程的API中的 “Java内置线程池”源码
java.util.concurrent.ThreadPoolExecutor

构造方法:
public ThreadPoolExecutor( int corePollSize,		// 核心线程数量
											int maximumPoolSize, 	// 最大线程数量
											long keepAlicveTime,	// 最大空闲时间
											TimeUnit unit,	//时间单位
											BlockingQueue<Runnable> workQueue,		//任务列队
											ThreadFactory threadFactory,	//线程工厂
											RejectExecutionHandle handler	//饱和处理啊机制   )
											{...}
参数分析

1:核心线程数(corePoolSize)
核心线程数的设计需要依赖任务的处理时间和每秒产生的任务数量来确定,例如执行一个任务需要0.1秒,系统百分之80的情况每秒产生100个任务,那么要想在一秒内处理啊完这100个任务,就需要10个线程,此时我们可以设计核心线程为10。

2:任务队列长度(workQueue)
任务长度一般设计为: 核心线程数 / (单个任务执行时间*2)

3:最大线程数(maximumPoolSize)
最大线程数 = ( 最大任务 - 任务队列长度 ) * 单个任务执行的时间。

4:最大空闲时间(keepAliveTime)
这个参数的设计完全参考系统运行环境和硬件压力设定,没有固定的参考值。
(包括以上三个参数,只是一般的设计原则,并不是固定的,用户也可以根据实际情况灵活调整)

自定义线程池-实现步骤
	1、编写任务类(MyTask),实现Runnable接口;
	2、编写线程类(MyWork),用于执行任务,需要持有所有任务;
	3、编写线程池类(My ThreadPool),包含执行任务,执行任务的能力;
	4、编写测试类(MyTest),创建线程池对象,提交多个任务测试;
代码实现例子:

1、编写任务类(MyTask),实现Runnable接口;

package com.MyThread;
/*
    要求:自定义线程练习,这是个任务类,需要实现Runnable 接口;
        包含任务编号,每个任务类的执行时间为0.2秒;
* */
public class MyTask implements Runnable {
   
    private int id;

    //由于run方法是重写接口中的方法。因此id的属性初始化可以利用构造方法完成。
    public MyTask(int id) {
   
        this.id = id;
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值