• 程序员谈话系列——线程池的魅力


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

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

    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:判断新任务是否达到核心线程数。

  • 相关阅读:
    python数据类型--字符串
    Cannot open include file: 'afxcontrolbars.h': No such file or directory
    关于找不到tbb_debug.dll解决办法
    Android fill_parent、wrap_content和match_parent的区别
    多个摄像头同步工作【转】
    如何查找openCV函数源代码[转]
    Opencv 完美配置攻略 2014 (Win8.1 + Opencv 2.4.8 + VS 2013)[转]
    CvCaptureFromCam
    OpenCV与相机的关系[转]
    10亿以内和987654互质正整数的和[转自深圳-冒泡]
  • 原文地址:https://www.cnblogs.com/ffdsj/p/12398144.html
Copyright © 2020-2023  润新知