![](https://img.haomeiwen.com/i7532387/ff98a7951a959385.png)
![](https://img.haomeiwen.com/i7532387/b1b2ae39303e1e81.png)
![](https://img.haomeiwen.com/i7532387/7cf8366b134ecf03.png)
![](https://img.haomeiwen.com/i7532387/5c54943dad7f2b50.png)
![](https://img.haomeiwen.com/i7532387/190676785b73c044.png)
volatile 不能保证一般变量的操作原子性原因是由于 volatile 不能保证非原子性操作的一致性,eg变量的++分为了3步,不是原子操作无法保证变量的一致性
![](https://img.haomeiwen.com/i7532387/7bb8bcb9a5d63384.png)
![](https://img.haomeiwen.com/i7532387/cb96515886dfbcd4.png)
主要原因以前很多计算机都是32位操作的,现在会读取2次,不过现在服务器都变成了64位了 其实不会出现这个情况。
Java通过Executors提供四种线程池,分别为:
newCachedThreadPool创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。
newFixedThreadPool 创建一个定长线程池,可控制线程最大并发数,超出的线程会在队列中等待。
newScheduledThreadPool 创建一个定长线程池,支持定时及周期性任务执行。
newSingleThreadExecutor 创建一个单线程化的线程池,它只会用唯一的工作线程来执行任务,保证所有任务按照指定顺序(FIFO, LIFO, 优先级)执行。
到这里,大部分朋友应该对任务提交给线程池之后到被执行的整个过程有了一个基本的了解,下面总结一下:
1)首先,要清楚corePoolSize和maximumPoolSize的含义;
2)其次,要知道Worker是用来起到什么作用的;
3)要知道任务提交给线程池之后的处理策略,这里总结一下主要有4点:
如果当前线程池中的线程数目小于corePoolSize,则每来一个任务,就会创建一个线程去执行这个任务;
如果当前线程池中的线程数目>=corePoolSize,则每来一个任务,会尝试将其添加到任务缓存队列当中,若添加成功,则该任务会等待空闲线程将其取出去执行;若添加失败(一般来说是任务缓存队列已满),则会尝试创建新的线程去执行这个任务;
如果当前线程池中的线程数目达到maximumPoolSize,则会采取任务拒绝策略进行处理;
如果线程池中的线程数量大于 corePoolSize时,如果某线程空闲时间超过keepAliveTime,线程将被终止,直至线程池中的线程数目不大于corePoolSize;如果允许为核心池中的线程设置存活时间,那么核心池中的线程空闲时间超过keepAliveTime,线程也会被终止。
网友评论