线程状态以及sleep yield wait join方法
前言
在日常的开发过程中,我们通过会使用Thread.sleep模拟一个耗时的任务执行过程。
在深入理解这四个方法之前,首先对线程的状态进行理解阐述。
线程概念
线程是操作系统执行任务的基本单位,处理器的数量决定了不可能所有的线程同时得到运行,这就意味着需要通过某种算法,如window下的抢占式,进行线程的调度。注:就绪也就是可运行状态,拥有CPU资源但还未处于运行中。
一个线程从开始到结束可能会有上述几种状态,之间可以互相转换。
Thread.sleep
Sleep意味着线程主动告诉操作系统自己要休息 n 毫秒。
- Thread.sleep(0) 进入就绪状态
如果n=0时,意味着当前线程的时间片没有用完,主动放弃自己剩下的时间片,进入就绪状态。这种情况下只能调度优先级相等或更高的线程,意味着优先级低的线程很难获得时间片,很可能永远都调用不到。当没有符合条件的线程,会一直占用 CPU 时间片,造成 CPU 100%占用率。 - Thread.sleep(1) 进入阻塞状态
如果n>0,会强制当前线程放弃剩余时间片,并休息n秒(因为不是实时操作系统,时间无法保证精确,一般可能会滞后几毫秒或一个时间片),进入阻塞状态。这种情况下所有其它就绪状态的线程都有机会竞争时间片,而不用在乎优先级。无论有没有符合的线程,都会放弃 CPU 时间,因此 CPU 占用率较低。
Thread.yield
Yield 的中文翻译为 “让步,让位”,这里意思是当前线程主动让出时间片,并让操作系统调度其它就绪态的线程使用时间片。
- 如果调用 Yield,只是把当前线程放入到就绪队列中,而不是阻塞队列
- 如果没有找到其它就绪态的线程,则当前线程继续运行
- 比 Thread.Sleep(0) 速度要快,可以让低于当前优先级的线程得以运行
Thread.wait
前面已经介绍过,详见通信机制:http://www.cnblogs.com/jjfan0327/p/6830478.html
Thread.join
作用:join方法的作用是加入其它线程,join方法的所在当前线程会将当前CPU执行权让给加入的线程(调用join方法的线程对象),直到加入线程执行完毕才会继续执行其它线程;
join在内部调用了wait(long)方法来实现的,所以join有释放锁的特点。ThreadA.join()表示如果线程A获抢到锁后,会调用内部wait方法,再次释放,使其他线程先执行完毕再抢占锁。
public final void join(); 这个方法会使当前调用的线程进行等待,直至调用的这个方法结束。如果线程被中断会抛出InterruptedException。
public final synchronized void join(long millis); 这个方法会使当调用的线程结束或者等待你声明的时长。等待的时间由操作系统决定。并不能保证当前的线程等待时间是确定的。
public final synchronized void join(long millis, int nanos); 同上,时间细化至毫微秒。
这面这个例子展示了Thread join 的用方法。这段代码的主要目的是确保main线程最后一个执行完,且第三个线程启必须等第一个线程执行完。
最新文章
- Code First 关系配置整理
- apache 一域名下多个二级域名如何做设置?
- another app is currently holding the yum lock;waiting for it to exit解决
- wireshark使用教程
- 使用RestTemplate Spring安全认证
- Android学习路径图
- HDU 1240——Asteroids!(三维BFS)POJ 2225——Asteroids
- MVC把随机产生的字符串转换为图片
- .NET框架设计—常被忽视的C#设计技巧
- 在Freeplane中显示与隐藏层级图标
- RPC简介与Thrift框架
- Facade ——为子系统的一组接口提供一致界面
- QQ第三方登录教程
- c++工程重复编译与重复定义
- win8如何共享文件夹
- void类型详解
- PAT 1026 程序运行时间(15)(C++&Java&Python)
- Alpha冲刺第9天
- 自定义oncontextmenu
- BZOJ 3230 相似子串 | 后缀数组 二分 ST表