学习
实践
活动
专区
工具
TVP
写文章

Java并发编程之——线程池

各位晚上好,马上过年了,顺手写写Java并发编程里的一点东西吧。

并发编程里一个重要的内容就是“线程池”。首先说说为什么要有线程池。因为使用线程池可以复用之前创建的线程,也可以提高响应的速度,而且使用线程池统一管理线程可以事半功倍,balabala......,总而言之,就是使用线程池可以提高效率。那么如何创建线程池呢?先看一张“神图”:

这两个是父接口与子接口的关系,请看源码:

Executor提供了一个execute(Runnable command)方法,该方法可以异步的执行。

还有一个特别厉害的类,那就是Executors类,这是一个线程池工具类,在Executors类里面提供了一些静态工厂,生成一些常用的线程池。今天介绍一个,那就是:

newSingleThreadExecutor()方法,用这个方法可以创建一个单线程的线程池。这个线程池只有一个线程在工作,那么当然就是这个线程串行执行所有任务了,如果这个唯一的线程因为种种原因被结束了,那么线程池就会创建新的线程来替代它。好了,代码如下(点击可放大图片):

那个绿圈的temp是为了测试查看数据的,运行结果为(限于篇幅,只显示部分结果):

注意那个"*************main",打印这句话的语句也在for循环里面,但是线程名称却是main,这说明了,只有ExecutorService里的execute(runnable)方法(这个方法也是继承父接口Executor的)体内部才是子线程的内容,而且这些子线程都是同一个线程,因为现在创建的是单线程的线程池。

好了,今天的内容就到这里,明天见。

  • 发表于:
  • 原文链接http://kuaibao.qq.com/s/20180209G1ASQV00?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

关注

腾讯云开发者公众号
10元无门槛代金券
洞察腾讯核心技术
剖析业界实践案例
腾讯云开发者公众号二维码

扫码关注腾讯云开发者

领取腾讯云代金券