JAVA并发编程
admin
2024-03-28 22:09:05
0

并发编程:
synchronized (悲观锁,非公平锁 ) 与 lock(reetrantLock,readwriteLock)(非公平锁、乐观锁)

synchronized:1.6之前为重型锁:线程获取不到锁会直接进入(锁池)队列等待直到上一个线程释放锁之后才可以争取锁

                        1.6之后引入了锁升级概念:JAVA对象头部(MarkWord)包含锁的信息,锁升级状态由无锁到第一次加锁升级为偏向锁,第二次加锁发生锁竞争则升级为轻量级锁,轻量级锁通过CAS自旋尝试获取锁,如仍然获取不到锁则升级为重量级锁进入锁池等待即1.6之前的方式

reetrantLock:底层采用CAS+AQS方式实现的锁机制,当一个线程想要获取锁先通过CAS自旋方式尝试获取锁;如获取不到则将当前线程封装为Node对象并存入AQS双向队列中,

                          1:AQS双向队列中已有线程在等待则将当前线程挂接在已有线程后面并将指针互相连接上,且挂接成功后会将上一个Node节点的状态(waitStatus)更新为-1表示上一个Node节点后面挂接的Node节点可被唤醒,处于AQS队列的头部Node节点会通过CAS方式尝试获取锁资源

                          2:AQS双向队列中没有线程在等待,则会创建一个虚拟的头部节点(head)并将当前Node节点挂接在虚拟节点之后,且将虚拟头部节点(head)的状态(waitStatus)设置为-1,以便更高效率的唤醒后面的线程节点

readwriteLock:读读不互斥,读写互斥,写写互斥;与reetranLock的区别在于更在细化的对锁的颗粒度做了区别,以适用读、写的不同场景下的效率提升

concurrentHashMap:多线程并发的线程安全集合类;采用数组+单向链接+红黑树的数据结构 ,当数组长度大于64(实则为了优化效率,数组的查询时间复杂度为O(1))且单向链表长度大于8(优化效率,单向链接的查询时间复杂度为O(n))时单向链接将转化成红黑树结构(时间复杂度Ologn)

CAS:比较并交换;程序运行时会先从内存中获取数据到CPU进行计算,再将计算完的结果写入到内存

                             1:如果多个线程同一时间从内存中获取同一份的数据进行计算则会引发数据不一致性的问题(其他线程不能及时拿到某一线程计算完写入的内存中的数据)

                              2:因此CAS的方式就是数据在CPU计算完之后写入到内存时,会比较此时内存中的值与当前CPU中获取的值是否一致,如一致则认为没有其它的线程修改过值正常写入,反之就认为值被其它线程篡改过则写入失败,再次通过CAS自旋方式直到写入成功为止

 Executors创建线程池的几种方式:

  newFixedThreadPool:固定线程数的线程池,当添加的线程数超过定义的线程数时则进入阻塞队列(LinkedBlockingQueue),遵循FIFO(先进先出)原则等待线程池中有空闲的线程数时再 进行工作

  newScheduledThreadPool:固定线程数的定时任务线程池,底层采用延迟队列(DelayedWorkQueue),可按固定的周期或者延迟多久的时间执行任务

newCachedThreadPool:创建存活时间为60秒的线程池,当前第一次有任务进来会直接创建新线程,如60秒内再次有任务进入会复用已创建的存活线程执行任务,如60秒内无任务进入则会结束当前线程池。如60秒外有任务进入则会创建新的线程执行;因为任务只要提交线程池中,就必然会有线程处理

newSingleThreadExecutor:单例线程池,线程池中只有一个线程在工作,后续进来的任务会进入到阻塞对列中等待,遵循FIFO(先进先出)原则,因此单例线程池适合按顺序执行的一系列任务

 newWorkStealingPool:并行计算底层使用ForkJoinPool;核心思想分而治之,线程窃取;使用场景,将一个大的任务按照一定的规则拆分(需手动编写拆分逻辑) 并放到当前线程的阻塞队列当中,其它的空闲线程可以去处理有任务的线程的阻塞列队中的任务 ,优点:线程池中空闲线程可以被充分利用                     

线程数计算:

核心线程数=cpu核数 * cpu利用率 * (1 + w/c)=cpu核数 * (1-阻塞系数)

相关内容

热门资讯

刺激!单日涨60%到跌60%,... 出品|达摩财经9月16日,妖股药捷安康(2617.HK)盘中一度上涨63.73%,并创出了679.5...
被群殴了,可恶啊... 被群殴... 图:simonbailly 服了服了。 今天自取其辱了 去年年底,我盘点过8个最常见的宽基指数。 就...
中概股深夜飙涨,百度涨超5%,... 记者丨吴斌 冯紫彤编辑丨李莹亮 曾芳 江佩佩9月16日晚,截至22:48,美股三大指数集体飘绿,美元...
一年关闭3.9万家,大批药店主... 一边是一年关店3.9万家,另一边是大批药店主动退出医保,发生了什么?能刷医保是药店吸引客户的主要卖点...
强一股份:八成营收“来自”隐名... 《金证研》南方资本中心 时安BR&DL/作者 西洲 映蔚/风控2025年以来,科创板加力推出“1+6...
稀土供需缺口支撑价格上行 固态... 8月以来,稀土产业链进入传统消费旺季,叠加稀土总量控制指标新规实施,稀土战略属性进一步凸显。同时,近...
热心投资者“撮合”!何时与国元... 华安证券、国元证券合并传闻由来已久。近日,又有投资者热心“撮合”两家的联姻。9月16日华安证券发布的...
长华集团:计划减持不超过538... 新京报贝壳财经讯 9月16日,长华集团公告称,公司计划通过集中竞价交易方式减持不超过538.06万股...
剑南春重新“拥抱”国资,绵竹国... 本文来源:时代周报 作者:幸雯雯剑南春重新“拥抱”国资了。近日,四川剑南春(集团)有限责任公司(下称...
深铁再掷20.64亿元“输血”... 新京报贝壳财经讯 (记者段文平)万科再获第一大股东深铁集团现金“驰援”。9月16日,万科公告称,深圳...