1.线程状态
1.2线程状态概述
-
线程由生到死的完整过程:技术素养和面试的要求。
-
线程从创建到销毁的过程称为线程的生命周期,在线程的生命周期内一共有六种状态:
线程状态 导致状态发生条件
NEW(新建) 线程刚被创建,但是并未启动。还没调用start方法。MyThread t = new MyThread()只有线程对象,没有线程特征。创建线程对象时
Runnable(可运行) 调用了 start() 方法,此时线程可能正在执行,也可能没有,这取决于操作系统的调度。调用start方法时 -
线程状态的切换
-
我们不需要去研究这几种状态的实现原理,我们只需知道在做线程操作中存在这样的状态。那我们怎么去理解这几个状态呢,新建与被终止还是很容易理解的,我们就研究一下线程从Runnable(可运行)状态与非运行状态之间的转换问题。
1.3计时等待和无限等待代码
计时等待
- public static void sleep(long time) 让当前线程进入到睡眠状态,到毫秒后自动醒来继续执行
代码
package com.itheima.demo4_线程.等待唤醒机制;
public class test {
public static void main(String[] args) throws InterruptedException {
// public static void sleep(long time) 让当前线程进入到睡眠状态,到毫秒后自动醒来继续执行
for (int i = 0; i < 100; i++) {
System.out.println("i:"+i);
// 暂停2秒
Thread.sleep(2000);
}
}
}
代码结果
i0 //暂停2秒后再循环下一次
i1
i2
i3
i4
i5
无限等待
Object类的方法:
- public void wait() : 让当前线程进入到等待状态 此方法必须锁对象调用.
- public void notify() : 唤醒当前锁对象上等待状态的线程 此方法必须锁对象调用.
代码
package com.itheima.demo4_线程.等待唤醒机制;
public class test2_1 {
static Object obj = new Object();
public static void main(String[] args) throws InterruptedException {
// 无限等待线程
// 创建并启动线程,让线程进入无限等待状态
new Thread(new Runnable() {
@Override
public void run() {
System.out.println("线程准备进入无限等待...");
//进入无限等待,并上锁
synchronized (obj) {
try {
obj.wait();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
// 线程被唤醒,继续执行
System.out.println("线程被唤醒,继续执行...");
}
}).start();
Thread.sleep(3000);//等待
//唤醒线程
new Thread(new Runnable() {
@Override
public void run() {
System.out.println("唤醒线程准备唤醒无限等待线程");
//唤醒
synchronized (obj){
obj.notify();
}
}
}).start();
}
}
代码结果
线程准备进入无限等待...
唤醒线程准备唤醒无限等待线程
线程被唤醒,继续执行...
1.4小结
- public static void sleep(long time) 让当前线程进入到睡眠状态,到毫秒后自动醒来继续执行
- public void wait() : 让当前线程进入到等待状态 此方法必须锁对象调用.
- public void notify() : 唤醒当前锁对象上等待状态的线程 此方法必须锁对象调用.
未完