java并发编程:线程安全性

多线程的优势

  • 提高资源使用率
  • 提高系统的吞吐量
  • 提高系统响应速度

多线程的风险

  • 线程安全性问题(对象可能会发生竞态条件)
  • 活跃性问题(线程可能会出现阻塞、死锁之类的问题)
  • 性能问题(线程的不合理使用,可能会导致资源竞争、内存占用过大等问题)

线程安全性的定义

线程安全性,实际上就是看线程是否按照我们所预期的方式运行,如果是,就是线程安全的,否则就是非线程安全的。

线程安全的实现方式

  • 线程封闭
    • ad-hot封闭。按照我的理解,是线程没有共享任何对象,也没有使用任何共享对象
    • 栈封闭。线程只使用局部变量。
    • ThreadLocal封闭。线程使用ThreadLocal在线程中传递对象。
  • 使用锁进行同步
    • 锁能保证被同一时间只能有一个线程能访问同步代码块
    • 锁的实现原理是:每个锁都有一个计数器,要获取锁时,会先检查计数器是否为0,如果是,则将该线程设置为锁的拥有者,计数器加1;否则,判断该线程是否是锁的拥有者,如果是,计数器加1,否则,阻塞该线程。
  • 将线程的状态设置为不可变对象,即final域
  • 用volatile修饰变量
    • volatile修饰的变量,在读取时,相当于进锁,写入时,相当于出锁。即同一时间只能有一个线程读取,但是可以有多个线程同时写入。
    • 由于volatile的特性,此方法只适用于“读取-写入”的变量,不适用于“读取-修改-写入”的变量。

你可能感兴趣的:(java并发编程)