Chapter 12 Java内存模型与线程

Java 内存模型是围绕并发过程中如何处理原子性、可见性、有序性来建立的。

  • 原子性
    通过 synchronized、LOCK解决
  • 可见性
    一个线程对变量的修改另一个线程能够立即察觉到
    通过synchronized、LOCK、volatile来解决
  • 有序性
    通过volatile 和 hapen-before原则保证

volatile

  1. 保证共享变量的可见性
  2. 禁止代码重排序

内存屏障

  1. lfence 是一种Load Barrier 读屏障
  2. sfence 是一种Store Barrier 写屏障
  3. mfence 是一种全能型的屏障,具备lfence 和 sfence的能力
  4. Lock前缀 lock 不是一种内存屏障,但是他能完成类似内存屏障的功能,lock 会对CPU总线和告诉缓存加锁,可以理解为CPU指令级的一种锁。

线程状态

  • 新建(New)
    创建后尚未启动的线程处于这种状态
  • 运行(Runnable)
    包括操作系统线程状态中的Running 和 Ready状态,也就是说线程正在执行,或者线程正在等待被CPU等待
  • 无限期等待(Waiting)
    处于这种状态的线程不会被分配CPU执行时间,要等待被其他线程显示唤醒
    • 没有设置超时时间的 wait() 方法
    • 没有设置超时时间的 join() 方法
    • LockSupport.park
  • 限期等待(Timed Waiting)
    处于这种状态的向后才能也不会被分配CPU执行时间,但是无需等待被其他线程显示唤醒,在等待一定时间后,他们由系统自动唤醒
    • Thread::sleep()
    • 设置了超时时间的 Object.wait()
    • 设置了超时时间的Thread::join()
    • LockSupport::parkNanos()
    • LockSupport::parkUntil
  • 阻塞(Blocked):
    线程被阻塞了,“阻塞状态” 与“等待状态”的区别是“阻塞状态”在等待着获取一个排它锁,这个时间将在另一个线程放弃这个锁的时候发生;而“等待状态”则是在等待一段时间,或者唤醒动作的发生。在程序进入同步区域的时候,线程将进入这种状态
  • 结束(Terminated)
    以终止的线程的状态,线程已经结束执行
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值