Thread与ThreadPoll

前台线程:主程序必须等待线程执行完毕后才可退出程序。Thread默认为前台线程,也可以设置为后台线程

后台线程:主程序执行完毕后就退出,不管线程是否执行完毕。ThreadPool默认为后台线程

线程消耗:开启一个新线程,线程不做任何操作,都要消耗1M左右的内存

ThreadPoll是线程池 其目的是为了减少开启新线程消耗的资源(使用线程池中的空闲线程,不必在开启新线程,以及统一管理线程(线程池中的线程执行完毕后,回归到线程池里,等待新任务).

总结:ThreadPoll性能优于Thread,但是Thread和ThreadPoll对线程的控制都不是很好,例如线程等待(线程执行一段时间无响应后,直接停止线程,释放资源 等 都没有直接的API来控制 只能通过硬编码来实现,同时ThreadPool使用的是线程池全局队列,全局队列中的线程依旧会存在竞争共享资源的情况,从而影响性能。

然后task

Task的背后的实现也是使用了线程池线程,但它的性能优于ThreadPoll,因为它使用的不是线程池的全局队列,而是使用的本地队列,使线程之间的资源竞争减少。同时Task提供了丰富的API来管理线程、控制。但是相对前面的两种耗内存,Task依赖于CPU对于多核的CPU性能远超前两者,单核的CPU三者的性能没什么差别。

Task不等于Thread,只是微软默认实现ThreadPoolTaskScheduler是依赖于线程池的,因为该类的可访问性为internal,所以我们在实际编码中无法直接在代码中new这么一个Scheduler出来,只能通过TaskScheduler.Default间接的来使用

最新文章

  1. BZOJ 1113: [Poi2008]海报PLA
  2. PHP-FPM-failed to ptrace(PEEKDATA) pid 123: Input/output error
  3. Simple Factory vs. Factory Method vs. Abstract Factory【简单工厂,工厂方法以及抽象工厂的比较】
  4. 机房管理系统——vb与excel链接2
  5. struts2,hibernate,spring整合笔记(4)--struts与spring的整合
  6. android 给layout布局添加点击事件
  7. 如何在spring中获取request对象
  8. Javascript Fromdata 与jQuery 实现Ajax文件上传以及文件的删除
  9. 读书笔记 effective c++ Item 45 使用成员函数模板来接受“所有兼容类型”
  10. Hadoop压缩
  11. mariadb 压缩包gz安装方式
  12. SpringBoot启动tomcat源码解读
  13. 在自定义目录下,按日期创建excel文件
  14. Luogu P2148 [SDOI2009]E&D
  15. gradle执行test任务报错
  16. python XML文件解析:用xml.dom.minidom来解析xml文件
  17. win7 下安装使用 nginx 出现500错误
  18. 20165205 2017-2018-2《Java程序设计》结对编程一 第一周总结
  19. 高德地图开发者平台获取sHA1值
  20. HBase启动时报错:/bin/java: No such file or directory6/bin/../bin/hbase: line 412: /usr/local/jdk1.8.0_152/bin/java

热门文章

  1. 22 严格模式&this关键词&let&const
  2. mpvue路由传参报错Cannot read property 'query' of undefined
  3. 常见排序的Java实现
  4. 【Java 二维码】生成二维码
  5. video兼容ie,ckplayer网页播放器
  6. redhat 7.6 流量监控命令、软件(2) iftop 监控网络IP实时流量
  7. C/C++网络编程6——实现基于UDP的服务器端/客户端
  8. 从npz文件中读取图片并显示的小例子
  9. 笔记-mongodb数据操作
  10. PTA的Python练习题(一)