首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在线程宏中记录值的惯用方式是什么?

在线程宏中记录值的惯用方式是什么?
EN

Stack Overflow用户
提问于 2017-11-26 05:18:19
回答 1查看 211关注 0票数 2

在我的代码中,我广泛地使用了线程宏。不过,有时我希望记录宏中的一个或多个值。例如,

代码语言:javascript
复制
(-> val
    (fn-1)
    (fn-2)
    (fn-3))

在这里,假设我想记录fn-2的结果。我该怎么做呢?

我试过两种方法:

  • trace放在fn-2后面。
  • fn-2之后添加一个匿名函数,比如#(do (log/debug %) %)

使用trace似乎并不理想,因为它不能与真正的记录器集成。滚动自己的功能似乎也不理想。

这里的最佳做法是什么?

EN

回答 1

Stack Overflow用户

发布于 2017-11-26 08:40:28

您可以创建一个更高级的debug函数,它用您想要的任何逻辑包装您的函数。下面是一个简单打印的示例:

代码语言:javascript
复制
(defn debug
  ([v d bmf] (debug v d bmf nil))
  ([v f before-msg-fmt amf]
   (let [r (f v)]
     (println (format before-msg-fmt v)
              (str (when amf (format amf r))))
     r)))

因此,使用以下函数调用它:

代码语言:javascript
复制
(def fn1 identity)
(def fn2 inc)
(def fn3 (fn[x] (* x 3)))

(-> 5
    (debug fn1 "here! %s")
    (debug fn2 "old val: %s" "new val: %s")
    fn3)

代码语言:javascript
复制
here! 5 
old val: 5 new val: 6
=> 18
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47493294

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档