在Andorid-27中查看Thread源码
第一次看Thread源码的时候,很是懵,看源码里面的注释感觉实在无法理解,随后在网上看各种关于Thread的讲解,感觉这篇文章讲的挺好的(文章地址:https://segmentfault.com/a/1190000016056471),对一些不理解的地方有所了解,然后再自己接着看源码。
public static native Thread currentThread():Thread.currentThread()返回的是当前线程(即执行这行代码时所在的线程)。
public static native void yield():Thread.yield():告诉调度器当前线程(即执行该行代码所在的线程)愿意放弃使用CPU。但是调度器可以同意也可以不同意,就是你表达了你的意愿,但怎么做是我的事。
public static void sleep(long millis, int nanos):
图1从图1中可以看出调用sleep方法后,当前线程陷入死循环中并持有对象锁直到millis时间过去,才开始向下执行。
Thread.sleep(millis):当前线程(即执行该行代码所在的线程)放弃它所占有的资源不再执行,但依然拥有对象锁,此时当前线程处TIMED_WAITING状态,等到millis后,就变成就绪状态,等待分配CPU,分配到CPU就从sleep的地方开始向下执行。
public synchronized void start() :调用start方法后,线程处于就绪状态,等待分配CPU,一旦分配到CPU之后就开始执行run方法。
public void interrupt() :中断线程
public final void join(long millis) throws InterruptedException :这个比较难理解,创建线程t,t.join加入到当前线程(即执行该行代码所在的线程),然后当前线程暂停执行,若millis=0则当前线程处于WAITING状态,等待加入的线程执行完成后,当前线程再接着执行;若millis>0则当前线程处于TIMED_WAITING状态,最多等待millis后,不论加入的线程是否执行完毕,当前线程都开始继续执行。
public final native void wait(long millis, int nanos) throws InterruptedException:让当前线程处于BLOCKED状态。 只有在当前线程持有自己的对象锁时才能调用此方法,调用后就会释放所持有的对象锁和占用的资源,等待millis后才有可能再次获取到所持有的对象锁。
接下来我们来看看线程所拥有的几种状态State:
1、NEW:创建一个线程,但还未调用start方法。
2、RUNNABLE:包含两种状态,运行状态和就绪状态,就绪状态就是都准备好了,等待分配CPU然后去执行
3、BLOCKED: 阻塞状态,等待获取监视器的锁。在运行时想要运行同步方法或同步代码块但未获取到对应的锁时会进入到阻塞状态。
4、WAITING:等待状态。调用了wait()/join()/LockSupport.park()后,就会进入该状态。
5、TIMED_WAITING:处于等待状态且有具体的等待时间。调用了Thread.sleep(long)/wait(long)/join(long)后,就会进入该状态。
6、TERMINATED:线程执行完成。
图2状态的切换如图2所示,参考文章:https://blog.csdn.net/pange1991/article/details/53860651
网友评论