一. 简介
1. start() :
API中对该方法的介绍是:
使该线程开始执行, Java虚拟机调用该线程的run方法
结果是两个线程并发进行, 当前线程(从调用返回给start方法)和另一个线程(执行其run方法)
多次启动一个线程是非法的, 特别是当线程已经结束执行后, 不能再重新启动
用start方法来启动线程, 真正实现了多线程运行, 这时无需等待run方法代码执行完毕而执行下面的代码, 通过调用Thread类的start()方法来启动线程, 这时此线程处于就绪状态, 并没有运行, 一旦得到cpu时间片, 就开始执行run()方法, 这里方法run()称为线程体, 它包含了要执行的这个线程的内容, run方法运行结束, 此线程随即终止
2. run()
API中对该方法的介绍是:
如果该线程是使用独立的Runnable运行对象构造的, 则调用该Runnable对象的run方法, 否则, 该方法不执行任何操作并返回.
Thread的子类应该重写该方法
run()方法只是类的一个普通方法而已, 可以被重复调用. 单独调用run()的话, 会在当前线程中执行run(), 而并不会启动新线程.
3. 总结
调用start方法可以启动线程, 而run方法只是thread的一个普通方法调用, 还是在主线程里执行
二. 代码实例
1. start()
public class TestStart {
public static void main(String[] args) {
Thread t = new Thread() {
@Override
public void run() {
pong();
}
};
t.start();
System.out.print("ping");
}
static void pong() {
System.out.print("pong");
}
}
运行结果是 pingpong
2. run()
public class TestRun {
public static void main(String[] args) {
Thread t = new Thread() {
@Override
public void run() {
pong();
}
};
t.run();
System.out.print("ping");
}
static void pong() {
System.out.print("pong");
}
}
运行结果是pongping
可以看出: t.start() 相当于是启动一个新线程, 并在新线程中运行run() 方法;
t.run() 相当于是使用t类中的run方法而已, 并不会启动一个新线程来运行run()