Thread.sleep()方法的作用是使当前线程休眠一段时间,例如:Thread.sleep(1000)就是让线程休眠1000毫秒,也就是1秒,但实际情况是线程等待的时间总是大于1000毫秒的,下面有段测试代码:
public class Demo {
public static void main(String[] args) throws InterruptedException {
long start = System.currentTimeMillis();
for (int i=0;i<1000;i++){
Thread.sleep(1);
}
long end = System.currentTimeMillis();
System.out.println((end-start));
}
}
如果Thread.sleep()休眠时间到了之后线程是立即执行的,那最后打印出来的结果会是1000,但实际情况总是大于1000的,其原因是Thread.sleep()方法的作用是使线程主动放弃cpu的执行权,并在休眠的这段时间内不参与cpu的竞争,在休眠结束后,线程并不能马上得到执行,而是进入就绪状态,参与cpu抢占,只有得到cpu的执行权才能继续执行,所以线程的休眠时间总是大于设置的时间的,并且当cpu越忙的时候这个误差越大。