java线程小结

  • 线程状态

java线程小结_第1张图片

NEW

顾名思义,这个状态,只存在于线程刚创建,未start之前

RUNNABLE

这个状态的线程,其正在JVM中执行,但是这个"执行",不一定是真的在运行, 也有可能是在等待CPU资源。所以,在网上,有人把这个状态区分为READY和RUNNING两个,一个表示的start了,资源一到位随时可以执行,另一个表示真正的执行中

BLOCKED

这个状态,一般是线程等待获取一个锁,来继续执行下一步的操作,比较经典的就是synchronized关键字,这个关键字修饰的代码块或者方法,均需要获取到对应的锁,在未获取之前,其线程的状态就一直未BLOCKED,如果线程长时间处于这种状态下,我们就是当心看是否出现死锁的问题了。

WAITING

一个线程会进入这个状态,一定是执行了如下的一些代码,例如

  • Object.wait()
  • Thread.join()
  • LockSupport.park()
    当一个线程执行了Object.wait()的时候,它一定在等待另一个线程执行Object.notify()或者Object.notifyAll()。
    或者一个线程thread,其在主线程中被执行了thread.join()的时候,主线程即会等待该线程执行完成。当一个线程执行了LockSupport.park()的时候,其在等待执行LockSupport.unpark(thread)。当该线程处于这种等待的时候,其状态即为WAITING。需要关注的是,这边的等待是没有时间限制的,当发现有

TIMED_WAITING

这个状态和WAITING状态的区别就是,这个状态的等待是有一定时效的,即可以理解为WAITING状态等待的时间是永久的,即必须等到某个条件符合才能继续往下走,否则线程不会被唤醒。但是TIMED_WAITING,等待一段时间之后,会唤醒线程去重新获取锁。当执行如下代码的时候,对应的线程会进入到TIMED_WAITING状态

  • Thread.sleep(long)
  • Object.wait(long)
  • Thread.join(long)
  • LockSupport.parkNanos()
  • LockSupport.parkUntil()

TERMINATED

即为线程执行结束之后的状态

创建线程的三种方式:

  • 继承自Thread类
  • 实现Runnable接口
  • 实现Callable接口

推荐使用第二种

保证高并发场景下的线程安全,可以从一下四个维度考量

  • 数据单线程内可见。单线程总是安全的ThreadLocal 就是采用这种方式来实现线程安全的。
  • 只读对象。
  • 线程安全类。
  • 同步与锁机制

java.util.concurrent包下的分类

  • 线程同步类
  • 并发集合类
  • 线程管理类
  • 锁相关类

参考资料:Java线程的6种状态分析

《码出高效 Java开发手册》

你可能感兴趣的