use*_*545 2 clojure clojurescript core.async
如果我有10个缓冲的订阅频道,每个频道都有一个需要5秒才能执行的传感器.换能器是同时执行还是全部在同一个线程上执行(假设多线程上下文)?
它很容易检查,记录线程,传感器正在执行:
(def log-chan (chan))
(go-loop []
(println (<! log-chan))
(recur))
(def channels
(repeatedly
10
#(chan 10
(map (fn [item]
(let [thread (Thread/currentThread)]
(go (>! log-chan thread)))
item)))))
(doseq [c channels]
(go (>! c :item)))
Run Code Online (Sandbox Code Playgroud)
输出:
#object[java.lang.Thread 0x77a39fa0 Thread[async-dispatch-27,5,main]]
#object[java.lang.Thread 0x7d5bf4d0 Thread[async-dispatch-31,5,main]]
#object[java.lang.Thread 0x53ecb32b Thread[async-dispatch-29,5,main]]
#object[java.lang.Thread 0x2b74f3ac Thread[async-dispatch-25,5,main]]
#object[java.lang.Thread 0x6eb50f9e Thread[async-dispatch-26,5,main]]
#object[java.lang.Thread 0x30701edb Thread[async-dispatch-30,5,main]]
#object[java.lang.Thread 0x1a370b69 Thread[async-dispatch-36,5,main]]
#object[java.lang.Thread 0x3d9884a2 Thread[async-dispatch-24,5,main]]
#object[java.lang.Thread 0x208941d0 Thread[async-dispatch-23,5,main]]
#object[java.lang.Thread 0x2c77aeb Thread[async-dispatch-28,5,main]]
Run Code Online (Sandbox Code Playgroud)
所以你可以看到,有不同的线程.
但它实际上取决于一个go块,你可以在其中向你的频道发送数据,所以如果你改变它:
(doseq [c channels]
(go (>! c :item)))
Run Code Online (Sandbox Code Playgroud)
对此:
(go (doseq [c channels]
(>! c :item)))
Run Code Online (Sandbox Code Playgroud)
你得到这个输出:
#object[java.lang.Thread 0x16856295 Thread[async-dispatch-6,5,main]]
#object[java.lang.Thread 0x16856295 Thread[async-dispatch-6,5,main]]
#object[java.lang.Thread 0x16856295 Thread[async-dispatch-6,5,main]]
#object[java.lang.Thread 0x16856295 Thread[async-dispatch-6,5,main]]
#object[java.lang.Thread 0x16856295 Thread[async-dispatch-6,5,main]]
#object[java.lang.Thread 0x16856295 Thread[async-dispatch-6,5,main]]
#object[java.lang.Thread 0x16856295 Thread[async-dispatch-6,5,main]]
#object[java.lang.Thread 0x16856295 Thread[async-dispatch-6,5,main]]
#object[java.lang.Thread 0x16856295 Thread[async-dispatch-6,5,main]]
#object[java.lang.Thread 0x16856295 Thread[async-dispatch-6,5,main]]
Run Code Online (Sandbox Code Playgroud)
所以所有通道的换能器都会使用相同的线程
| 归档时间: |
|
| 查看次数: |
468 次 |
| 最近记录: |