线程池(重点)
线程池:三大方法、七大参数、四种拒绝策略
池化技术:
程序运行本质:占用系统的资源!优化资源的使用!=>池化技术
example:线程池,连接池,内存池,对象池。
池化技术:事先准备好一些资源,有人要用,就来我这里来拿,用完之后还给我。
线程池的好处:
①降低资源的消耗
②提高响应的速度
③方便管理
④线程复用,可以控制最大并发数,管理线程——最主要作用
线程池:三大方法
七大参数:
①newSingleThreadExecutor源码分析
②newFixedThreadPool源码分析
③newCachedThreadPool源码分析
本质:调用ThreadPollExecutor
手动创建一个线程池
四种拒绝策略
*拒绝策略1:newThreadPoolExecutor.AbortPolicy()
银行满了还有人进来,不处理这个人的并抛出异常——超出最大承载
*拒绝策略2:newThreadPoolExecutor.CallerRunsPolicy()
哪来的去哪里,多余的是main线程进行处理
*拒绝策略3:newThreadPoolExecutor.DiscardPolicy());
队列满了,丢掉任务(不执行)不会抛出异常,
*拒绝策略4:newThreadPoolExecutor.DiscardOldestPolicy());队列满了会尝试去和最早的竞争,竞争成功则执行,否则就丢掉任务,不抛出异常
最大线程到底如何定义
最大线程到底如何定义
1:CPU密集型——几核就是几,可以保持CPU效率最高
2:IO密集型——>判断尼彻那个续重十分耗资IO的进程,数目可以定位2被
程序中15个大型任务,io十分占用资源