线程的状态:
线程状态有5种,创建,就绪,运行,终止,阻塞,关系如图;
常用的线程操作方法?
- 得到线程对象:Thread类的currentThread();
- 得到线程名称:Thread类的getName();
- 设置线程名称:Thread类的setName(String name);
- 创建线程的时候设置名字:Thread类的构造方法public Thread(Runnable target,String name);
- 线程休眠:Thread类的sleep(long time);----让线程休眠一段时间,到了时间后再恢复执行,sleep方法是不会释放锁的,如果当前线程持有某个对象的锁,就算调用了sleep方法,其他线程也无法访问到该对象。
- 线程让步:Thread类的yield()----暂停当前正在执行的线程对象(让出CPU),并执行其他线程。此方法也不会释放锁,此方法只能让拥有相同优先级的线程优先获取CPU的机会。
- 等待线程终止:join()----看程序会更好理解,在主线程main执行过程中,调用了thread.join(),这个thread是子线程A,在主线程中调用子线程A的join方法会让主线程休眠,直到子线程执行完,再回来执行主线程。
class MyThread implements Runnable {
@Override
public void run() {
try {
System.out.println("主线程睡眠前的时间");
Test.printTime();
Thread.sleep(2000);
System.out.println(Thread.currentThread().getName());
System.out.println("睡眠结束的时间");
Test.printTime();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
public class Test {
public static void main(String[] args) throws InterruptedException{
MyThread mt = new MyThread();
Thread thread = new Thread(mt,"⼦线程A");
thread.start();
System.out.println(Thread.currentThread().getName());
thread.join();
System.out.println("代码结束");
}
public static void printTime() {
Date date=new Date();
DateFormat format=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
String time=format.format(date);
System.out.println(time);
}
}
结果:
可以看到这个方法和sleep有些类似,但是sleep不会释放锁,所以在线程sleep时,别的线程并不能访问该对象,但是join可以,可以看到,在main休眠时,子线程执行了,看一下join的源码:
join的底层是用wait()实现的,所以join会释放锁。
在这些方法的执行过程中,线程的状态也在改变,如图: