1.调用start()方法:
通知“线程规划器”当前线程已经准备就绪,等待调用线程对象的run()方法。这个过程就是让系统安排一个时间来调用Thread中的run()方法,使线程得到运行,启动线程,具有异步执行的效果。
调用start()方法,也就是线程状态转变成可运行状态的过程。
2.调用run()方法:
不是异步执行,而是同步执行,当前线程并不交给“线程规划器”来处理,而是由main主线程来调用run()方法,也就是必须等run()方法中的代码执行完后才可以执行后面的代码。
启动区别:
1 public class MainTest { 2 3 public static void main(String[] args) { 4 Thread thread=new ThreadDemo(); 5 //第一种 6 //表明: run()和其他方法的调用没任何不同,main方法按顺序执行了它,并打印出最后一句 7 //thread.run(); 8 9 //第二种 10 //表明: start()方法重新创建了一个线程,在main方法执行结束后,由于start()方法创建的线程没有运行结束, 11 //因此主线程未能退出,直到线程thread也执行完毕.这里要注意,默认创建的线程是用户线程(非守护线程) 12 //thread.start(); 13 14 //第三种 15 //1、为什么没有打印出100句呢?因为我们将thread线程设置为了daemon(守护)线程,程序中只有守护线程存在的时候,是可以退出的,所以只打印了七句便退出了 16 //2、当java虚拟机中有守护线程在运行的时候,java虚拟机会关闭。当所有常规线程运行完毕以后, 17 //守护线程不管运行到哪里,虚拟机都会退出运行。所以你的守护线程最好不要写一些会影响程序的业务逻辑。否则无法预料程序到底会出现什么问题 18 //thread.setDaemon(true); 19 //thread.start(); 20 21 //第四种 22 //用户线程可以被System.exit(0)强制kill掉,所以也只打印出七句 23 thread.start(); 24 System.out.println("main thread is over"); 25 System.exit(1); 26 } 27 28 } 29 class ThreadDemo extends Thread{ 30 @Override 31 public void run() { 32 for (int i = 0; i < 100; i++) { 33 System.out.println("This is a Thread test"+i); 34 } 35 } 36 37 }