我第一次使用猫来解决代码出现的第一天,我想知道是否有可能改进事情。
给定update
具有以下签名
的方法def update(i: Instruction): PosAndDir => PosAndDir
我想出了:
val state: State[PosAndDir, List[Unit]] = instructions.map(i => State.modify(update(i))).toList.sequenceU
val finalState = state.runS(PosAndDir(Pos(0, 0), North)).value
并且
def update2(i: Instruction): State[PosAndDir, Option[Pos]] =
State.modify(update(i)).inspect(pad => if (i == Walk) Some(pad.pos) else None)
…
val state = instructions.map(update2).toList.sequenceU
val positions = state.runA(PosAndDir(Pos(0, 0), North)).value.flatten
更准确地说,问题是:
- 为什么我们需要调用
.value
(使用 scalaz,它是透明的)? - 有没有办法
update2
用理解来提高可读性? - 猫中有没有
Applicative
实例Seq
(我知道scalaz中没有)。? - 有什么改进代码的想法吗?