在玩 Clojure 中的并发调用时println
,我发现它的行为与 Java 的System.out.println
.
我会用 Java 写什么
class Pcalls {
public static void main(String[] args) {
Runnable[] fns = new Runnable[3];
for (int i = 0; i < 3; i++) {
fns[i] = new Runnable() {
@Override public void run() {
for (int i = 1; i <= 5; i++) {
System.out.println("Hello iteration " + i);
}
}
};
}
for (Runnable fn : fns) new Thread(fn).start();
}
}
我在 Clojure 中解释为:
(doall (apply pcalls
(repeat 3 #(dotimes [i 5] (println "Hello iteration" (inc i))))))
不幸的是,在 Clojure 版本中,输出行经常交错出现:
Hello iterationHello iteration 1
Hello iteration Hello iteration 2
Hello iteration 3
1
Hello iteration 4
1
Hello iteration Hello iteration5
Hello iteration 2
Hello iteration 23
Hello iteration Hello iteration 4
3Hello iteration
5
Hello iteration 4
Hello iteration 5
(nil nil nil)
在 Java 中这永远不会发生,每条消息都打印在自己的行上。
您能否解释一下 Clojureprintln
与 Java 的不同之处和原因,以及如何在 Clojure 中实现类似的“线程安全”行为println
?