zoukankan      html  css  js  c++  java
  • 程序员谈话系列——线程池的魅力

    一,为什么要使用线程池呢?

    池化技术就是为了减少每次获取资源的消耗,提高对资源的利用率。线程池提供了一种限制和管理资源,每个线程池维护一些基本的统计信息。

    1.降低了资源消耗,通过重复利用已创建的线程减低线程创建和销毁的消耗。

    2.提高响应的速度。当任务到达时,任务可以不需要等到线程创建就能立即执行。

    3.提高线程的可管理性。线程是稀缺资源,如果无限制的创建,不仅会消耗系统资源,还会降低系统的稳定性,使用线程池可以进行统一的分配,调优和监控。

    二,使用Runnable接口和Callable接口的区别。

    1)Runnable不支持返回结果或抛出检查异常,但是Callable支持。所以不需要返回结果的时候使用Runnable接口。使用工具类Executors可以实现Runnable对象和Callable对象之间的相互转换。(Executors.callable(Runnabletask))或Excutors.callable(Runnable task,Object resule)。

    三,执行execute()方法和submit()方法的区别是什么?

    1)execute()方法用于提交不需要返回值的任务,所以无法判断任务是否执行成功与否

    2)submit()方法用于提交需要返回值的任务,线程池会返回一个Future类型的对象,通过这个Future对象可以判断任务是否执行成功,并且可以通过Future的get()方法来获取返回值,get()方法会阻塞当前线程直到任务完成,而使用get(long timeout,TimeUnit unit)方法则会阻塞当前线程一段时间后立即返回,这时候有可能任务没有执行完。

    四,如何创建一个线程池?

    最好使用ThreadPoolExecutor创建,因为Executors方法里面有FixedThreadPool等很容易导致oom。

    方法一:通过构造方法实现。

    方法二:通过Executor框架的工具类Executors来实现我们可以创建三种类型的ThreadPoolExecutor:

    FixedThreadPool:返回一个固定线程数量的线程池。

    SingleThreadExecutor:返回一个只有一个线程的线程池。

    CachedThreadPool:该方法返回一个根据实际情况调整线程数量的线程池,线程数量不确定。

    ThreadPoolExcutor中3个重要的参数:

    corePoolSize:最小可以同时运行的线程数量。

    maximumPoolSize:最大容量

    workQueue:判断新任务是否达到核心线程数。

  • 相关阅读:
    hbase 由于zookeeper问题导致连接失败问题
    Python 判断文件/目录是否存在
    mysql5.7设置默认的字符集
    mysql 提示ssl问题
    Ubuntu 安装MySQL报共享库找不到
    hbase 监控指标项
    大量数据通过Phoenix插入到hbase报错记录(2)
    通过phoenix导入数据到hbase出错记录
    mysql5.7 之 sql_mode=only_full_group_by问题
    Hadoop 在启动或者停止的时候需要输入yes确认问题
  • 原文地址:https://www.cnblogs.com/ffdsj/p/12398144.html
Copyright © 2011-2022 走看看