线程是靠cpu来运行的,cpu要运行一个线程(不说别的)最起码就是要占用cpu时间,象Windows这样的多任务操作系统,可以允许多个线程同时运行,所谓的同时运行并不是真正的同时运行,而是轮流运行不同的线程,因为cpu速度很快,如果线程不是很多,就会给用户有所有线程在同时运行的错觉。cpu的调度都是内核来做的,表面上用户进程自己执行自己的,其实内核很忙的。他会不断的挂起某个线程,去执行另一个线程,回头再恢复那个线程。
先说阻塞,阻塞就是内核突然让cpu去干别的事情了,用户你要等待内核返回消息。
然后挂起,挂起其实是用户主动行为,一旦挂起,线程就不在需要cpu,内核也不需要再考虑它用不用cpu,直到用户恢复状态。
sleep(n),他表示用户线程放弃当前的cpu时间片,n秒后参与cpu使用。sleep(0)是有特殊含义的,他表示此时此刻我放弃cpu时间片,别人可以执行,然后马上参与cpu竞争。
相关文章
- Java线程阻塞方法sleep()与wait()的全面讲解
- 多线程,线程类三种方式,线程调度,线程同步,死锁,线程间的通信,阻塞队列,wait和sleep区别?
- 理解线程的挂起,sleep还有阻塞
- Python进阶----异步同步,阻塞非阻塞,线程池(进程池)的异步+回调机制实行并发, 线程队列(Queue, LifoQueue,PriorityQueue), 事件Event,线程的三个状态(就绪,挂起,运行) ,***协程概念,yield模拟并发(有缺陷),Greenlet模块(手动切换),Gevent(协程并发)
- Java中一个线程只有六个状态。至于阻塞、可运行、挂起状态都是人们为了便于理解,自己加上去的。