我剛開始學習線程,並誤解了它們的工作原理。使線程正常工作
這裏是我的類:
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
線程的目的不是並行執行嗎?
也許我需要同步一些東西?還是犯了粗心的錯誤?要麼…?
請解釋。
UPDATE:
爲什麼我看不到,讓我們說:
0 started
1 started
0 finished
2 started
1 finished
2 finished
謝謝大家接受治療。
你的英文很好。好問題。 – sje397 2010-12-07 17:38:14
@ sje397謝謝你,先生! – Mick 2010-12-07 17:55:03