了解并发

我所理解的并发,就是多个任务(可以是进程,线程,协程)同时执行,以更快的完成任务。并发和硬件关系密切,cpu核数、cpu缓存、CAS底层实现等都是并发编程时需要考虑的。在java中,提到并发,定然会谈锁,以下就简单了解下并发:
1 java中常用的并发控制的关键字
volatile:通过不缓存到栈来保证可见性,变量获取时会直接从cpu获取。
用途:一般用作发生中断结束等状态的标志,无法保证原子性,所以不能做计数器或互斥体
sychronized:内置锁,可重入,分对象锁和类锁
2显示锁:可定时,可轮询,可中断。互斥锁:reentrantlock:提供公平和非公平性两种。读写锁:readwritelock,大大提交读的并发性能。
3死锁:一般是竞争资源引起。
如何避免死锁:3.1 可定时可轮询的锁tryLock
3.2可中断的锁
3.3获取锁的顺序要一致
3.4最好使用开放调用,就是将同步封装,而不是调用方来同步
3.5减少锁的持有时间
3.6减少锁的范围,降低锁的粒度
4活锁 :当多个相互协作的线程都对彼此进行相应从而修改自己的状态,并使得任何一个线程都无法继续执行时,就发生了活锁。不要过度得错误恢复代码,在重试机制中添加次数限制或引入随机性。
5 避免独占锁的方式
锁分解
锁分段:比如concurrentHashmap分解为16段
使用并发容器,原子变量,不可变对象
6显示的Condition对象
与Lock结合实现有界缓存队列,比使用wait和notify更灵活
7jvm
自旋锁:获取失败时隔一段时间再重试
偏向锁:第一次获取锁后会设置变量偏向该线程,之后再获取该锁不需要重新cas,直接使用来提高性能
8同步工具类
闭锁
CountDownLaunch
FutureTask
信号量
栅栏
8线程池
Executor框架
newFixedThreadPool
newSingleThreadPool
newCachedThreadpool
newScheduledThreadPool
Callable
Future
CompletionService
将executor和blockingqueue结合,方便实时的获取每个任务的执行结果并处理
timer的局限性:单线程,有异常会终止,叫线程泄漏
9线程间通信
通过Objet的wait和notify实现,对象上的锁的切换
10数据库领域的并发
乐观并发控制
乐观离线锁
通过版本号检测每次提交
悲观并发控制
悲观离线锁
独占写锁
独占读锁
读写锁
事务
原子性
一致性
隔离性
持久性
11 actor模型
执行体之间通过消息来交互

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱美事爱生活

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值