public class ThreadTest {
static Integer slots = 0;
static Integer tasks = 0;
/**
* @param args
*/
public static void main(String[] args) {
Test t = new Test();
// t.start();
t.run() ;
System.out.println(" main ");
}
}
class Test extends Thread
{
public void run() //启动一个workload
{
try {
sleep(10000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println("test1");
}
}
使用Thread的run方法和start()方法,得到不同的结果, 不知道为啥
1. 主线程中使用run方法时, 始终结果是
test1
main
2. 当改成start()方法时:
main
test1
区别:调用start方法实现多线程,而调用run方法没有实现多线程
Start:
用start方法来启动线程,真正实现了多线程运行,这时无需等待run方法体代码执行完毕而直接继续执行下面的代码。通过调用Thread类的start()方法来启动一个线程,这时此线程处于就绪(可运行)状态,并没有运行,一旦得到spu时间片,就开始执行run()方法,这里方法run()称为线程体,它包含了要执行的这个线程的内容,Run方法运行结束,此线程随即终止。
Run:
run()方法只是类的一个普通方法而已,如果直接调用Run方法,程序中依然只有主线程这一个线程,其程序执行路径还是只有一条,还是要顺序执行,还是要等待run方法体执行完毕后才可继续执行下面的代码,这样就没有达到写线程的目的。
总结:调用start方法方可启动线程,而run方法只是thread的一个普通方法调用,还是在主线程里执行。
本文详细解析了Java中Thread类的start方法与run方法的不同之处,通过具体示例展示了两者在执行过程中的差异,解释了为何start方法能够实现真正的多线程并发执行。
2132

被折叠的 条评论
为什么被折叠?



