可以使用 Lwt.return 作为递归函数中的最终调用吗?
我有一个编译得很好但运行不正常的函数,它看起来像f
下面的函数。请假设g
本示例中提供的任何功能都没有问题,我基本上只是想找出具有以下形式的功能是否可以,或者是否有更好/更简单(并且符合 Lwt)的方式执行以下操作:
let rec f (x : string list) (g : string -> unit Lwt.t) =
match List.length x with
| 0 -> Lwt.return ()
| _ -> g (List.hd x) >>= fun () -> f (List.tl x) g
;;
val f : string list -> (string -> unit Lwt.t) -> unit Lwt.t = <fun>
我很确定我做错了。但是我使用的实际功能比这个例子复杂得多,所以我很难调试它。