cla*_*laj 4 clojure core.async
当然,我想用core.async将各种请求包装到外部服务,同时仍然通过一些操作返回这些操作的结果chan
.
我想要处理抛出的异常和超时(即操作需要比预期更长的时间才能返回,或者能够在相同任务的各种服务中进行选择,但具有不同的方法或服务质量.
显示能够处理错误,超时和正确返回结果的示例的最小可行示例似乎是:
(require '[clojure.core.async :refer [chan go timeout <! >! alt!]])
(def logchan (chan 1))
(go (loop []
(when-let [v (<! logchan)]
(println v)
(recur))))
(dotimes [_ 10]
(go
(let [result-chan (chan 1)
error-chan (chan 1)
timeout-chan (timeout 100)]
(go
(try
(do (<! (timeout (rand-int 200)))
(>! result-chan (/ 1 (rand-int 2))))
(catch Exception e (>! error-chan :error))))
(>! logchan (alt! [result-chan error-chan timeout-chan]
([v] (if v v :timeout)))))))
Run Code Online (Sandbox Code Playgroud)
这段代码打印出像
1
:error
1
:error
:error
:timeout
:error
:timeout
:timeout
Run Code Online (Sandbox Code Playgroud)
这不是很优雅.我特别不喜欢返回的方式:error
和:timeout
.该nil
在-check alt!
显然不是我想要的任何.
有没有更好的方法来实现返回结果的三个目标,防止长时间超时并处理错误?语法很好(上面的大多数事情都是为了引发这三个错误).
core.async -function chan
具有ex-handler,因此可以使用以下构造
(chan buf-or-n xform ex-handler)
Run Code Online (Sandbox Code Playgroud)
where ex-handler
是一个获得异常的单参数函数.当函数返回时nil
,这不会放在通道上,否则函数有机会将异常转换为可用于所讨论数据的可行内容.
归档时间: |
|
查看次数: |
1070 次 |
最近记录: |