Java 并发编程实战

第二章 线程安全性

定义:当多个线程访问某个类时,这个类始终能表现出正确的行为。

2.1

  • 无状态对象一定是线程安全的

    • 不包含任何属性

    • 不包含对其他类属性的引用

2.2 原子性

  • ++ 操作并非原子性,不安全

  • 竞态条件:在并发编程中,由于不恰当的执行时序而出现不正确的结果

    • 最常见:先检查后执行操作;++:基于错误的结果做判断

    • 一个时间差,系统状态发生改变:2人约在咖啡厅见,但是去了有2个咖啡厅

    • 正确的执行结果取决于事件发生的时序

  • 原子类操作:

    java.util.concurrent.atomic
    • 不良并发

      • 可同时调用的资源数量,不仅受到可用处理资源的限制,还受程序本身结构的限制

    • 简单性与性能之间存在相互制约因素

    • 当执行时间较长的计算,一定不要持有锁

    2.3 加锁机制

    • 内置锁:synchronized

      • 同步代码块,以原子方式执行

      • 静态synchronized方法以Class对象作为锁

      • 是一种互斥锁:即最多只有一个线程能持有该锁-->等待或堵塞

    • 重入

      • 某线程试图获得一个他已经持有的锁,该请求会成功

      • 内置锁是可重入的

      • 锁的操作粒度是线程,不是调用

    2.5 活跃性与性能

  • 不良并发

    • 可同时调用的资源数量,不仅受到可用处理资源的限制,还受程序本身结构的限制

  • 简单性与性能之间存在相互制约因素

  • 当执行时间较长的计算,一定不要持有锁

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值