多线程的实现方式
前言
本文从两方面介绍线程,一:线程的生命周期,二多线程实现的方式
1:线程的生命周期
线程的生命周期的几种状态:
新建状态
就绪状态:当线程调用start()方法之后,该线程就进入就绪状态。就绪状态的线程处于就绪队列中,要等待JVM里线程调度器的调度。
运行状态:如果就绪状态的线程获取CPU资源,就可以执行run()方法,此时线程便处于运行状态。
阻塞状态:可以分为以下三种
(1)等待阻塞:运行状态中的线程执行wait()方法,使线程进入到等待阻塞状态。
(2)同步阻塞:线程在获取synchronized同步锁失败(因为同步锁被其他线程占用)
(3)其他阻塞:运行的线程执行sleep()或join()方法,或者发出了I/O请求时,JVM会把该线程置为阻塞状态。当sleep()状态超时、join()等待线程终止或者超时、或者I/O处理完毕时,线程重新转入就绪状态。
死亡状态:线程执行完了或者因异常退出了run()方法,该线程结束生命周期。
2:多线程实现的方式
方式有很多,这里我介绍3种方式 a.继承Thread类,b.实现Runnable接口,c.ExecutorService
2.1继承Thread类
public class MyThread1 extends Thread{
public void run(){
System.out.println(MyThread1.currentThread().getName());
}
}
main方法:
MyThread1 thread1 = new MyThread1();
thread1.start();
MyThread1 thread2 = new MyThread1();
thread2.start();
运行结果:
Thread-0
Thread-1
2.2实现Runnable接口
main方法:
Thread thread3 = new Thread(new Runnable() {
@Override
public void run() {
System.out.println("thread3 运行");
}
});
thread3.start();
运行结果:
thread3 运行
2.3ExecutorService
这种方式请参看我的另一篇ExecutorService方式实现多线程。