什么情形下适合使用线程池技术

原创 2012年03月27日 14:51:41
线程池适用情况:
单位时间内处理数目巨大的连接请求,但处理时间相对较短。主要特点就是使用与创建技术,将线程创建和销毁本身带来的开销分摊到具体任务上,任务执行次数越多,则节省时间越多。再有一个就是线程池采用与创建技术创建的线程池规模一般有一个上界,可以解决一些服务器无法同时创建一定量数目线程的问题。线程池将与线程执行相关的任务进行了高层次的抽象,使之与具体的执行任务无关。另外该线程池具有动态伸缩性,它能根据执行任务的轻重自动调整线程池中线程的数量.(除了使用waitxxx也可以手动挂起启动线程来实现,不过这样就比较麻烦了,以为我们还是要设置一个管理线程来监听事件的发生然后对线程池中各个线程的状态进行调整,还不如让线程池中线程来直接监听等待事件等对象的到来)
如果我们需要处理的是一个长连接,即个连接上都是一个执行时间很长的任务,甚至就是一个不会停止的任务,这样我们就没有必要使用线程池技术。而是直接采取“即时创建、即时销毁”的策略就可以了。这就是所说的我们要根据实际的需求状况设计不同的解决方案。

为什么需要线程池?
目前的大多数网络服务器,包括Web服务器、Email服务器以及数据库服务器等都具有一个共同点,就是单位时间内必须处理数目巨大的连接请求,但处理时间却相对较短。 传统多线程方案中我们采用的服务器模型则是一旦接受到请求之后,即创建一个新的线程,由该线程执行任务。任务执行完毕后,线程退出,这就是是“即时创建, 即时销毁”的策略。尽管与创建进程相比,创建线程的时间已经大大的缩短,但是如果提交给线程的任务是执行时间较短,而且执行次数极其频繁,那么服务器将处 于不停的创建线程,销毁线程的状态。 
我们将传统方案中的线程执行过程分为三个过程:T1、T2、T3。 T1:线程创建时间 T2:线程执行时间,包括线程的同步等时间 T3:线程销毁时间 那么我们可以看出,线程本身的开销所占的比例为(T1+T3) / (T1+T2+T3)。如果线程执行的时间很短的话,这比开销可能占到20%-50%左右。如果任务执行时间很频繁的话,这笔开销将是不可忽略的。 除此之外,线程池能够减少创建的线程个数。通常线程池所允许的并发线程是有上界的,如果同时需要并发的线程数超过上界,那么一部分线程将会等待。而传统方 案中,如果同时请求数目为2000,那么最坏情况下,系统可能需要产生2000个线程。尽管这不是一个很大的数目,但是也有部分机器可能达不到这种要求。 因此线程池的出现正是着眼于减少线程池本身带来的开销。线程池采用预创建的技术,在应用程序启动之后,将立即创建一定数量的线程(N1),放入空闲队列 中。这些线程都是处于阻塞(Suspended)状态,不消耗CPU,但占用较小的内存空间。当任务到来后,缓冲池选择一个空闲线程,把任务传入此线程中 运行。当N1个线程都在处理任务后,缓冲池自动创建一定数量的新线程,用于处理更多的任务。在任务执行完毕后线程也不退出,而是继续保持在池中等待下一次 的任务。当系统比较空闲时,大部分线程都一直处于 暂停状态,线程池自动销毁一部分线程,回收系统资源。 基于这种预创建技术,线程池将线程创建和销毁本身所带来的开销分摊到了各个具体的任务上,执行次数越多,每个任务所分担到的线程本身开销则越小,不过我们另外可能需要考虑进去线程之间同步所带来的开销。


 


                    

什么时候用线程池

线程池不是什么时候都要用的,他也是一种资源,用的不对可能并不会带来性能上的提高,正确的使用方法是有一堆任务需要创建线程去执行,任务就是对象,在java里面,就好比是实现了Runnable接口的对象,那...
  • bravekingzhang
  • bravekingzhang
  • 2011年11月09日 17:37
  • 4536

什么时候手动创建线程而不使用线程池

1、需要自定义线程的优先级,线程池中线程总是Normal2、需要一个前台线程,线程池中线程是后台线程     非UI线程最好使用线程池创建为后台线程,常常关闭一个软件之后,仍然占有内存,就是由于创建了...
  • love__coder
  • love__coder
  • 2011年05月12日 15:45
  • 3072

多线程必须用到的线程池(什么时候用多线程)

案例需求:要开发的项目是一个IT问答平台,其中用户发布问题后,需要给平台上所有选了该问题类别的邮箱中各发一份邮件。 分析:这个时候就必须用到多线程了,因为用户发布问题和给其他用户发邮件可以说是两...
  • qq_32079585
  • qq_32079585
  • 2017年09月01日 16:52
  • 224

dotnet多线程(基础篇、WinForm多线程编程篇、线程池、同步、什么时候需要锁定)

  • 2010年08月13日 16:25
  • 290KB
  • 下载

【使用线程池的好处】多线程的环境中,尽量采用线程池

在什么情况下使用线程池?      1.单个任务处理的时间比较短      2.将需处理的任务的数量大      使用线程池的好处:      1.减少在创建和销毁线程上所花的时间...
  • kavensu
  • kavensu
  • 2012年10月20日 20:00
  • 30496

为什么要使用线程池

在Java中,如果每当一个请求到达就创建一个新线程,开销是相当大的。在实际使用中,每个请求创建新线程的服务器在创建和销毁线程上花费的时间和消耗的系统资源,甚至可能要比花在处理实际的用户请求的时间和资源...
  • a497393102
  • a497393102
  • 2013年02月21日 11:51
  • 6910

如何和何时使用多线程

如何和何时使用多线程2007-05-15 23:04 摘要:本章讨论与智能客户端应用程序中多线程的使用有关...
  • jupiter97
  • jupiter97
  • 2007年05月24日 11:19
  • 4459

总结-Java何时需要使用多线程

不定期更新,谢谢,欢迎补充。 多线程使用的主要目的在于: 1、吞吐量:你做WEB,容器帮你做了多线程,但是他只能帮你做请求层面的。简单的说,可能就是一个请求一个线程。或多个请求一个线程。如果...
  • wujizkm
  • wujizkm
  • 2016年02月11日 20:20
  • 6337

Java四种线程池的使用

Java通过Executors提供四种线程池,分别为: newCachedThreadPool创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。 new...
  • hupitao
  • hupitao
  • 2014年04月25日 09:28
  • 19024

Java并发编程:线程池的使用(非常棒,通俗易懂)

Java并发编程:线程池的使用   在前面的文章中,我们使用线程的时候就去创建一个线程,这样实现起来非常简便,但是就会有一个问题:   如果并发的线程数量很多,并且每个线程都是执行一个时间...
  • u011531613
  • u011531613
  • 2017年03月13日 16:56
  • 14807
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:什么情形下适合使用线程池技术
举报原因:
原因补充:

(最多只允许输入30个字)