小编典典
现在,我的理解是,当调用start()时,JVM隐式(立即)调用了run()方法。
那是不对的。它确实隐式调用run(),但是调用不一定立即发生。
现实情况是,在进行start()调用之后的某个时间点,可以安排新线程使用。实际调度取决于本机调度程序。它可能会立即发生,或者父线程可能会在安排子线程之前持续一段时间。
为了强制您的线程立即开始运行(或者更准确地说,是在之前开始运行doSomethingElse()),您需要执行一些显式同步;例如这样的事情:
java.util.concurrent.CountDownLatch latch = new CountdownLatch(1);
new Thread(new MyRunnable(latch)).start();
latch.await(); // waits until released by the child thread.
doSomethingElse();
哪里
class MyRunnable implements Runnable {
private CountDownLatch latch;
MyRunnable (CountDownLatch latch) { this.latch = latch; }
public void run() {
doSomeStuff();
latch.countDown(); // releases the parent thread
doSomeMoreStuff();
}
...
}
还有其他方法可以使用并发类或Java的互斥/等待/通知原语1实现同步。但是,两个线程之间的显式同步是保证所需行为的唯一方法。
请注意,doSomething()子线程中的调用将在释放父线程之前完成,但是我们不能说doSomethingElese()和的执行顺序doSomeMoreStuff()。(一个可以在另一个之前运行,反之亦然,或者它们可以并行运行。)
1- 不建议使用wait/ notify,但是如果并发API不可用,它可能是您唯一的选择;例如在Java ME上。
2020-09-26