JAVA进阶之路——无奖问答挑战2

JAVA问答第二篇

引言

这里引用b站JAVA韩顺平说过的话鼓励大家

万丈高楼平地起,辉煌还得靠自己

我与大家一起坚持,不要放弃啊!


Q1:为什么要用线程池?

  • 如果不使用线程池,频繁地创建和销毁线程会带来巨大的系统开销。线程池主要解决了以下三个问题:
    降低资源消耗:通过复用已创建的线程,减少了线程创建和销毁所带来的CPU和内存开销。
  • 提高响应速度:任务到达时,无需等待线程创建,直接由池中空闲线程执行,响应极快。
  • 提高可管理性:线程是稀缺资源,无限制创建会导致系统崩溃。线程池可以统一管理线程生命周期,控制最大并发数,甚至进行监控和统计。

Q2:线程池的核心组成部分是啥?

一个标准的线程池通常由以下三部分组成:

  1. 线程池管理器:负责创建、销毁线程池,以及分配任务。
  2. 工作线程(Worker Threads):实际执行任务的线程,执行完任务后不会死亡,而是返回池中等待。
  3. 任务队列(Task Queue):当所有线程都在忙碌时,新来的任务会先被放入这个队列中排队等待。

Q3:讲讲线程池的参数?

参数名 说明
corePoolSize 核心线程数。常驻线程,即使空闲也不会被销毁(除非开启特殊配置)。
maximumPoolSize 最大线程数。线程池能容纳的线程总数上限(核心+临时)。
keepAliveTime 存活时间。非核心线程(临时工)空闲时的存活时间,超时会被回收。
workQueue 工作队列。核心线程满时,任务会进入队列等待。
handler 拒绝策略。队列满且线程数达到最大值时,新任务的处理方式。

Q4: 线程池的工作流程是啥?

当一个新任务提交给线程池时,它会按照以下顺序进行处理:

  1. 优先分配给核心线程:如果当前运行的线程数少于 corePoolSize,线程池会创建新线程来执行任务(即使有空闲线程),直到达到核心线程数。
  2. 尝试入队:如果核心线程都在忙,线程池会尝试将任务放入 workQueue 队列。
  3. 扩容非核心线程:如果队列也满了,且当前线程数小于 maximumPoolSize,线程池会创建"非核心线程"来执行任务。
  4. 触发拒绝策略:如果线程数达到最大值且队列也满,线程池会启动拒绝策略(如抛出异常、丢弃任务、或由调用者线程自己执行等)。

Q5:HTTP与HTTPS的区别?

比较维度 HTTP HTTPS
安全性 低(明文传输,数据裸奔) 高(加密传输,防窃听/篡改)
默认端口 80 端口 443 端口
协议基础 基于 TCP 协议 HTTP + SSL/TLS 加密层
证书要求 不需要证书 需要向 CA 机构申请数字证书
SEO 排名 较低(被搜索引擎降权) 较高(搜索引擎优先收录)
相关推荐
Re_zero35 分钟前
线上日志被清空?这段仅10行的 IO 代码里竟然藏着3个毒瘤
java·后端
洋洋技术笔记41 分钟前
Spring Boot条件注解详解
java·spring boot
程序员清风19 小时前
程序员兼职必看:靠谱软件外包平台挑选指南与避坑清单!
java·后端·面试
皮皮林55120 小时前
利用闲置 Mac 从零部署 OpenClaw 教程 !
java
华仔啊1 天前
挖到了 1 个 Java 小特性:var,用完就回不去了
java·后端
SimonKing1 天前
SpringBoot整合秘笈:让Mybatis用上Calcite,实现统一SQL查询
java·后端·程序员
日月云棠2 天前
各版本JDK对比:JDK 25 特性详解
java
用户8307196840822 天前
Spring Boot 项目中日期处理的最佳实践
java·spring boot
JavaGuide2 天前
Claude Opus 4.6 真的用不起了!我换成了国产 M2.5,实测真香!!
java·spring·ai·claude code
IT探险家2 天前
Java 基本数据类型:8 种原始类型 + 数组 + 6 个新手必踩的坑
java