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-阻塞系数)

相关内容

热门资讯

突然爆雷!深夜,暴跌30%!欧... 黑天鹅突袭,欧洲汽车巨头暴跌。隔夜美股盘中,欧洲汽车巨头——斯特兰蒂斯(Stellantis)股价一...
美团为何要花50亿元,下一单叮... 「核心提示」从大众点评、饿了么,到叮咚买菜,起家上海的本地生活“优等生”,为何总被巨头收编?作者 |...
存储涨价负面效应初现:一台服务... 《科创板日报》2月7日讯 随着存储涨价传导至下游,海外传统行业已开始受到负面影响。据ZDNet Ko...
巨头砸钱6500亿加剧担忧,黄... 在科技巨头不断加大AI领域支出激化市场的泡沫担忧之际,英伟达CEO黄仁勋公开发声“灭火”,为动辄数千...
厂二代靠短视频破局,自媒体成接... 临近年底,一个新的玩法开始在社交媒体上走红,这就是不少知名企业的少爷小姐们开始依靠短视频出圈,这些原...
联合国秘书长发表声明:欢迎伊朗... △联合国秘书长古特雷斯(资料图) 当地时间2月6日,联合国秘书长古特雷斯通过新闻发言人发表声明,欢迎...
山西“十四五”期间建成80余家... 11月17日消息,“十四五”期间,山西省级研发投入约50亿元,建成80余家省级以上能源科技创新平台,...
300亿身价爱尔眼科董事长,牵... 出品|达摩财经一起精神病院涉嫌骗取医保资金的案件,牵涉到了爱尔眼科(300015.SZ)实控人陈邦。...
竟是一疑似“骗保”精神病院实控... 文丨英英编辑丨杜海来源丨新商悟(本文约为1300字)免费住院暗藏医保黑洞,一位眼科大佬的精神病院生意...
倍轻松实控人马学军再被立案调查... 倍轻松(688793.SH)实际控制人马学军再遭立案调查。2026年2月6日公告显示,公司于2月4日...