一、认识Thread的 start() 和 run()
t.start()会导致run()方法被调用,run()方法中的内容称为线程体,它就是这个线程需要执行的工作。
用start()来启动线程,实现了真正意义上的启动线程,此时会出现异步执行的效果,即在线程的创建和启动中所述的随机性。
而如果使用run()来启动线程,就不是异步执行了,而是同步执行,不会达到使用线程的意义
1.start():
“start()方法会使得该线程开始执行;java虚拟机会去调用该线程的run()方法。”
使该线程开始执行;Java 虚拟机调用该线程的run方法。
结果是两个线程并发地运行;当前线程(从调用返回给start方法)和另一个线程(执行其run方法)。
多次启动一个线程是非法的。特别是当线程已经结束执行后,不能再重新启动。
用start方法来启动线程,真正实现了多线程运行,这时无需等待run方法体代码执行完毕而直接继续执行下面的代码。通过调
用Thread类的 start()方法来启动一个线程,这时此线程处于就绪(可运行)状态,并没有运行,一旦得到cpu时间片,就开始
执行run()方法,这里方法 run()称为线程体,它包含了要执行的这个线程的内容,Run方法运行结束,此线程随即终止。
2.run():
publicclassThreadextendsObjectimplementsRunnable
如果该线程是使用独立的Runnable运行对象构造的,则调用该Runnable对象的run方法;否则,该方法不执行任何操作并返回。
Thread的子类应该重写该方法。
run()方法只是类的一个普通方法而已,如果直接调用Run方法,程序中依然只有主线程这一个线程,其程序执行路径还是只有
一条,还是要顺序执行,还是要等待run方法体执行完毕后才可继续执行下面的代码,这样就没有达到写线程的目的。
总结
调用start方法方可启动线程,而run方法只是thread的一个普通方法调用,还是在主线程里执行。
Thread thread=new Thread(){
@Override
public void run() {
testPwd();
}
};
// thread.start();
thread.run();
System.out.print("启动线程...");
}
// 测试线程方法
static void testPwd(){
System.out.println("是否进来...");
}
thread.start();
启动线程...是否进来...
thread.run();
是否进来...
11:01:39.720 [新线程] INFO com.whjz.workstation.RunnableT - 线程名:新线程
启动线程...11:01:39.720 [新线程] INFO com.whjz.workstation.RunnableT - 线程名:新线程
11:01:39.720 [新线程] INFO com.whjz.workstation.RunnableT - 线程名:新线程