Я только начал изучать темы и столкнулся с неправильным пониманием того, как они работают.
Вот мой класс:
public class MyThread extends Thread {
private static int NUM = 0;
private int id;
public MyThread() {
id = NUM++;
}
public static void main(String[] args) {
for (int i = 0; i < 10; i++) {
new MyThread().start();
}
}
public void run() {
System.out.println(id + " started");
try {
Process p = Runtime.getRuntime().exec("javac -version");
p.waitFor();
} catch (Exception e) {
System.out.println("Call a doc!");
}
System.out.println(id + " finished");
}
}
/*
Just a sidenote.
I am creating new javac process just to slow an application down.
Simple System.out.println(…) is a way faster.
*/
Почему я всегда получаю все «… Начались» сообщения сначала, а после этого «… закончены» сообщения?Независимо от того, сколько потоков я запустил, я всегда вижу:
0 started
1 started
2 started
3 started
4 started
5 started
6 started
7 started
8 started
9 started
0 finished
1 finished
3 finished
4 finished
8 finished
5 finished
2 finished
6 finished
9 finished
7 finished
Разве потоки не предназначены для распараллеливания выполнения?
Может быть, мне нужно что-то синхронизировать?Или совершил неосторожную ошибку?Или ...?
Объясните, пожалуйста.
ОБНОВЛЕНИЕ:
Почему я не вижу, скажем:
0 started
1 started
0 finished
2 started
1 finished
2 finished
СпасибоВы все на лечение.