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

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

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密集型)合理配置。

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

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

相关文章:

  • 介绍Unity中的Dictionary
  • 【RAG技术全景解读】从原理到工业级应用实践
  • 树莓派5+Ubuntu24.04 LTS串口通信 保姆级教程
  • Mockoon 使用教程
  • 解决:‘java‘ 不是内部或外部命令,也不是可运行的程序-Java环境变量配置(含JDK8、JDK21安装包一站式配置)
  • 垃圾厌氧堆肥发酵实验台试验装置
  • 直接用字符串方式 split(“。“) 来切句,虽然能把句子拆开,但无法和 BERT 模型的 token 位置对应(embedding 用不上)
  • 两种方法求解最长公共子序列问题并输出所有解
  • Android学习总结之算法篇八(二叉树和数组)
  • 可视化图解算法35:在二叉树中找到两个节点的最近公共祖先(二叉树的最近公共祖先)
  • 【LeetCode】删除排序数组中的重复项 II
  • 2025年渗透测试面试题总结-某步在线面试(题目+回答)
  • 开启智能Kubernetes管理新时代:kubectl-ai让操作更简单!
  • ZooKeeper工作机制与应用场景
  • 邻近标记技术:研究蛋白互作的利器(五)
  • base64与图片的转换和预览(高阶玩法)
  • 守护数字家园:个人博客安全防护指南
  • 云服务如何简化物联网设备生命周期(How Cloud Services Simplify IoT Device Lifecycles)?
  • 【Linux修炼手册】Linux开发工具的使用(一):yum与vim
  • 数据清洗(ETL/ELT)原理与工具选择指南:企业数字化转型的核心引擎
  • 免费手机端网站模板下载/百度指数名词解释
  • 广告公司微网站建设/网络营销的重要性
  • 奉节做网站/最吸引人的营销广告文案
  • 市场策划/seo整站排名
  • 提供信息门户网站建设/sem外包
  • 东莞网站推广案例/武汉网站提升排名