通常,系统通过调用线程类的start()方法来启动一个线程,此时线程处于就绪状态而非运行状态,也就意味着这个线程可以被JVM来调度执行。在调度过程中,JVM通过调用线程类的run()方法来完成实际的操作,当run()方法结束后,此线程就会终止。
如果直接调用线程的run()方法,这会被当做一个普通函数的调用,程序中仍然只有主程序这一个线程,也就是说,start()方法能够异步地调用run()方法,但是直接调用run()却是同步的;因此也就无法达到多线程的目的。
一句话,只有调用线程类的start()方法才能够达到多线程的目的。
package fromBook;
class threadDemo extends Thread{
public void run() {
System.out.println("ThreadDemo:begin");
try {
Thread.sleep(1000);
}catch(Exception e) {
e.printStackTrace();
}
System.out.println("ThreadDemo:end");
}
}
public class Test {
public static void test1() {
System.out.println("test1:begin");
Thread t1 = new threadDemo();
t1.start();
System.out.println("test1:end");
}
public static void test2() {
System.out.println("test2:begin");
Thread t2 = new threadDemo();
t2.run();
System.out.println("test2:end");
}
public static void main(String[] args) {
test1();
try {
Thread.sleep(5000);
}catch(Exception e) {
e.printStackTrace();
}
test2();
}
}
运行结果为:
test1:begin
test1:end
ThreadDemo:begin
ThreadDemo:end
test2:begin
ThreadDemo:begin
ThreadDemo:end
test2:end
总结:
从test1中可以看出,线程 t1 在 test1 方法执行结束后执行 的(System.out.println(“test1:end”),语句不需要等t1.start()运行结果就可以执行),因此,在test1中调用start()方法是异步的,所以main线程与t1线程是异步执行的。
从 test2 的运行结果可以看出,调用t1.run()是同步的调用方法,因为System.out.println(“test2:end”)只有等t1.run()调用结束后才能执行。