当前位置: 首页 > web >正文

线程池的核心参数和线程创建方式,线程和进程

Java线程池的核心参数

Java线程池通过ThreadPoolExecutor类进行配置,其核心参数如下:

  1. corePoolSize(核心线程数)

    • 作用:线程池中保持活动的最小线程数,即使这些线程处于空闲状态。

    • 行为:默认情况下,核心线程不会因空闲超时被回收(除非设置allowCoreThreadTimeOut(true))。

  2. maximumPoolSize(最大线程数)

    • 作用:线程池允许创建的最大线程数(包括核心线程和非核心线程)。

    • 触发条件:当核心线程全忙且阻塞队列已满时,会创建临时线程,直到达到此值。

  3. keepAliveTime(空闲线程存活时间)

    • 作用:非核心线程(临时线程)在空闲状态下的存活时间,超时后会被终止。

    • 单位:通过TimeUnit指定(如秒、毫秒)。

  4. workQueue(阻塞队列)

    • 作用:存储等待执行的任务。

    • 常用类型

      • LinkedBlockingQueue:无界队列(默认容量极大,需警惕内存溢出)。

      • ArrayBlockingQueue:有界队列(需指定容量)。

      • SynchronousQueue:不存储任务,直接提交给线程处理。

  5. threadFactory(线程工厂)

    • 作用:自定义线程的创建方式(如设置线程名称、优先级)。

    • 示例

      java

      复制

      下载

      ThreadFactory factory = r -> {Thread t = new Thread(r);t.setName("custom-thread-" + t.getId());return t;
      };
  6. handler(拒绝策略)

    • 作用:当线程池和队列均满时,处理新提交的任务。

    • 内置策略

      • AbortPolicy(默认):抛出RejectedExecutionException

      • CallerRunsPolicy:由提交任务的线程直接执行。

      • DiscardPolicy:静默丢弃任务。

      • DiscardOldestPolicy:丢弃队列中最旧的任务,重新提交当前任务。


Java中线程的创建方式

  1. 继承Thread类

    java

    复制

    下载

    class MyThread extends Thread {@Overridepublic void run() {System.out.println("Thread running");}
    }
    MyThread t = new MyThread();
    t.start();
  2. 实现Runnable接口

    java

    复制

    下载

    Runnable task = () -> System.out.println("Runnable running");
    Thread t = new Thread(task);
    t.start();
  3. 实现Callable接口(支持返回值)

    java

    复制

    下载

    Callable<String> task = () -> "Result";
    ExecutorService executor = Executors.newSingleThreadExecutor();
    Future<String> future = executor.submit(task);
    String result = future.get(); // 阻塞获取结果
    executor.shutdown();
  4. 使用线程池(推荐)

    java

    复制

    下载

    ExecutorService executor = Executors.newFixedThreadPool(4);
    executor.submit(() -> System.out.println("Task executed by thread pool"));
    executor.shutdown();

线程(Thread)与进程(Process)的区别

特性进程线程
资源分配独立内存空间(堆、栈、系统资源)共享进程的内存空间(堆),独立栈
创建开销大(需分配独立资源)小(共享进程资源)
通信方式复杂(如管道、Socket、共享内存)简单(直接共享内存,但需同步控制)
切换成本高(涉及上下文切换和资源切换)低(仅切换线程上下文)
独立性一个进程崩溃不影响其他进程一个线程崩溃可能导致整个进程终止
应用场景需要隔离的任务(如浏览器多标签页)高并发任务(如Web服务器处理请求)

线程池的工作流程

  1. 任务提交

    • 若核心线程未满,立即创建新线程执行。

    • 若核心线程全忙,任务进入阻塞队列。

  2. 队列处理

    • 队列未满时,任务排队等待核心线程处理。

    • 队列已满时,创建临时线程(直到达到maximumPoolSize)。

  3. 拒绝策略触发

    • 当线程池和队列均满时,执行拒绝策略。


示例:自定义线程池

java

复制

下载

ThreadPoolExecutor executor = new ThreadPoolExecutor(2,                              // corePoolSize4,                              // maximumPoolSize60, TimeUnit.SECONDS,           // keepAliveTimenew ArrayBlockingQueue<>(10),    // workQueuenew CustomThreadFactory(),      // threadFactorynew ThreadPoolExecutor.CallerRunsPolicy() // handler
);// 提交任务
for (int i = 0; i < 15; i++) {executor.submit(() -> {try {Thread.sleep(1000);System.out.println(Thread.currentThread().getName() + " 执行任务");} catch (InterruptedException e) {e.printStackTrace();}});
}executor.shutdown();

总结

  • 线程池核心参数:需根据任务类型(CPU/IO密集型)合理配置。

  • 线程创建方式:推荐使用线程池管理线程,避免频繁创建销毁开销。

  • 线程与进程:线程轻量且共享资源,适合高并发;进程隔离性强,适合需要独立环境的任务。

http://www.xdnf.cn/news/4695.html

相关文章:

  • rust程序静态编译的两种方法总结
  • 手势、鼠标滑动实现界面切换
  • 介绍Unity中的Dictionary
  • npm包之serve-favicon
  • flow-matching 之学习matcha-tts cosyvoice
  • 集团云解决方案:集团企业IT基础架构的降本增效利器
  • RAG技术在测试用例生成中的应用
  • FAST角点检测算法原理附C++代码实现
  • HarmonyOS NEXT之深度解析ArkUI自定义组件:从基础实现到生产级登录组件的进化之路
  • 复盘20250508
  • CSS:元素显示模式与背景
  • 【Java ee 初阶】文件IO和操作(下)
  • 系统架构-面向服务架构(SOA)
  • 【嵌入式开发-SPI】
  • 常见的提示词攻击方法 和防御手段——提示词注入(Prompt Injection)攻击解析
  • 了解Dockerfile
  • 【计算机网络 第8版】谢希仁编著 第四章网络层 题型总结2
  • 如何用分布式防御抵扣大规模DDoS攻击?
  • 【PostgreSQL数据分析实战:从数据清洗到可视化全流程】电商数据分析案例-9.2 流量转化漏斗分析
  • 前端实战中的单例模式:以医疗药敏管理为例
  • [论文笔记] 超详细解读DeepSeek v3全论文技术报告
  • 零基础入门Hadoop:IntelliJ IDEA远程连接服务器中Hadoop运行WordCount
  • TDEngine 与 Grafana
  • 从零开始在亚马逊云科技 EC2上部署DeepSeek R1大语言模型:完整实战指南
  • Linux 网络命名空间:从内核资源管理到容器网络隔离
  • 算法与数据结构 - 常用图算法总结
  • 观测云:安全、可信赖的监控观测云服务
  • 《React Native性能优化:从卡顿到丝滑的蜕变之旅》
  • 菊厂笔试1
  • Django rest_framework 信号机制生成并使用token