start
start作用是启动一个新线程。
当用start()开始一个线程后,线程就进入就绪状态,使线程所代表的虚拟处理机处于可运行状态,这意味着它可以由JVM调度并执行。但是这并不意味着线程就会立即运行。只有当CPU分配时间片时,这个线程获得时间片时,才开始执行run()方法。start()不能被重复调用,它调用run()方法,run()方法是你必须重写的。
run
run()就和普通的成员方法一样,可以被重复调用。
如果直接调用run方法,并不会启动新线程!程序中依然只有主线程这一个线程,其程序执行路径还是只有一条,还是要顺序执行,还是要等待run方法体执行完毕后才可继续执行下面的代码,这样就没有达到多线程的目的。
调用start方法方可启动线程,而run方法只是thread的一个普通方法调用,还是在主线程里执行。
start()和run()方法的区别:
- start方法用来启动相应的线程;
- run方法只是thread的一个普通方法,在主线程里执行;
- 需要并行处理的代码放在run方法中,start方法启动线程后自动调用run方法;
- run方法必须是public的访问权限,返回类型为void。
参考示例代码:
package com.zeus;
class TestCall extends Thread {
public void run() {
System.out.println("running...");
}
public static void main(String args[]) {
TestCallRun1 t1 = new TestCallRun1();
t1.run();// fine, but does not start a separate call stack
}
}
执行上面示例代码,得到以下结果:
running...
如果直接调用run()
方法,则会出现问题。参考以下示例代码:
package com.zeus;
class TestCall extends Thread {
public void run() {
for (int i = 1; i < 5; i++) {
try {
Thread.sleep(500);
} catch (InterruptedException e) {
System.out.println(e);
}
System.out.println(i);
}
}
public static void main(String args[]) {
TestCallRun2 t1 = new TestCallRun2();
TestCallRun2 t2 = new TestCallRun2();
t1.run();
t2.run();
}
}
执行上面示例代码,得到以下结果:
1
2
3
4
1
2
3
4
正如在上面的程序中看到的那样,程序执行并没有上下文切换,因为这里t1
和t2
将被视为普通对象而不是线程对象。