线程休眠注意点
- sleep(时间)指定当前线程阻塞的毫秒数
- sleep存在异常InterruptedException
- sleep时间达到后线程进入就绪状态
- sleep可以模拟网络延时,倒计时等
- 每个对象都有一个锁,sleep不会释放锁
线程休眠实例
//模拟网络延时:放大问题的发生性
public class TestSleep implements Runnable{
//票数
private int ticketNums = 10;
@Override
public void run() {
while (true){
if (ticketNums <= 0){
break;
}
//模拟延时
try {
Thread.sleep(200);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName()+"--》拿到了第"+ticketNums--+"票");
}
}
public static void main(String[] args) {
TestSleep ticket = new TestSleep();
new Thread(ticket,"小明").start();
new Thread(ticket,"老师").start();
new Thread(ticket,"小红").start();
}
}
执行结果
老师--》拿到了第9票
小明--》拿到了第10票
小红--》拿到了第8票
老师--》拿到了第7票
小明--》拿到了第7票
小红--》拿到了第7票
老师--》拿到了第6票
小红--》拿到了第4票
小明--》拿到了第5票
小明--》拿到了第3票
老师--》拿到了第2票
小红--》拿到了第1票
public class TestSleep2 {
public static void main(String[] args) {
//模拟倒计时
try {
tenDown();
} catch (InterruptedException e) {
e.printStackTrace();
}
//打印系统当前时间
Date startTime = new Date(System.currentTimeMillis());//获取系统当前时间
while (true){
try {
Thread.sleep(1000);
System.out.println(new SimpleDateFormat("HH:mm:ss").format(startTime));
startTime = new Date(System.currentTimeMillis());//更新当前时间
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
public static void tenDown() throws InterruptedException {
int num = 10;
while (true){
Thread.sleep(1000);
System.out.println(num--);
if (num<=0){
break;
}
}
}
}
执行结果
10
9
8
7
6
5
4
3
2
1
17:06:35
17:06:36
17:06:37