JAVA问答第二篇
- 引言
- Q1:为什么要用线程池?
- Q2:线程池的核心组成部分是啥?
- Q3:讲讲线程池的参数?
- [Q4: 线程池的工作流程是啥?](#Q4: 线程池的工作流程是啥?)
- Q5:HTTP与HTTPS的区别?
引言
这里引用b站JAVA韩顺平说过的话鼓励大家
万丈高楼平地起,辉煌还得靠自己
我与大家一起坚持,不要放弃啊!
Q1:为什么要用线程池?
- 如果不使用线程池,频繁地创建和销毁线程会带来巨大的系统开销。线程池主要解决了以下三个问题:
降低资源消耗:通过复用已创建的线程,减少了线程创建和销毁所带来的CPU和内存开销。 - 提高响应速度:任务到达时,无需等待线程创建,直接由池中空闲线程执行,响应极快。
- 提高可管理性:线程是稀缺资源,无限制创建会导致系统崩溃。线程池可以统一管理线程生命周期,控制最大并发数,甚至进行监控和统计。
Q2:线程池的核心组成部分是啥?
一个标准的线程池通常由以下三部分组成:
- 线程池管理器:负责创建、销毁线程池,以及分配任务。
- 工作线程(Worker Threads):实际执行任务的线程,执行完任务后不会死亡,而是返回池中等待。
- 任务队列(Task Queue):当所有线程都在忙碌时,新来的任务会先被放入这个队列中排队等待。
Q3:讲讲线程池的参数?
| 参数名 | 说明 |
|---|---|
| corePoolSize | 核心线程数。常驻线程,即使空闲也不会被销毁(除非开启特殊配置)。 |
| maximumPoolSize | 最大线程数。线程池能容纳的线程总数上限(核心+临时)。 |
| keepAliveTime | 存活时间。非核心线程(临时工)空闲时的存活时间,超时会被回收。 |
| workQueue | 工作队列。核心线程满时,任务会进入队列等待。 |
| handler | 拒绝策略。队列满且线程数达到最大值时,新任务的处理方式。 |
Q4: 线程池的工作流程是啥?
当一个新任务提交给线程池时,它会按照以下顺序进行处理:
- 优先分配给核心线程:如果当前运行的线程数少于 corePoolSize,线程池会创建新线程来执行任务(即使有空闲线程),直到达到核心线程数。
- 尝试入队:如果核心线程都在忙,线程池会尝试将任务放入 workQueue 队列。
- 扩容非核心线程:如果队列也满了,且当前线程数小于 maximumPoolSize,线程池会创建"非核心线程"来执行任务。
- 触发拒绝策略:如果线程数达到最大值且队列也满,线程池会启动拒绝策略(如抛出异常、丢弃任务、或由调用者线程自己执行等)。
Q5:HTTP与HTTPS的区别?
| 比较维度 | HTTP | HTTPS |
|---|---|---|
| 安全性 | 低(明文传输,数据裸奔) | 高(加密传输,防窃听/篡改) |
| 默认端口 | 80 端口 | 443 端口 |
| 协议基础 | 基于 TCP 协议 | HTTP + SSL/TLS 加密层 |
| 证书要求 | 不需要证书 | 需要向 CA 机构申请数字证书 |
| SEO 排名 | 较低(被搜索引擎降权) | 较高(搜索引擎优先收录) |