欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 汽车 > 新车 > 线程池的核心参数和线程创建方式,线程和进程

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

2025/5/9 7:36:17 来源:https://blog.csdn.net/m0_57350451/article/details/147804826  浏览:    关键词:线程池的核心参数和线程创建方式,线程和进程

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

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

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

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词