haskell - 功能性镜片

标签 haskell functional-programming lenses

有人可以向我解释一下功能性镜片吗?对于谷歌来说,这是一个令人惊讶的困难主题,而且我还没有取得任何进展。我所知道的是它们提供了与 OO 类似的获取/设置功能。<​​/p>

最佳答案

透镜由两个函数组成:getter 和 setter:

data Lens a b = Lens { getter :: a -> b, setter :: b -> a -> a }

例如,我们可能有用于一对的第一部分和第二部分的镜片:

fstLens :: Lens (a, b) a
fstLens = Lens fst $ \x (a, b) -> (x, b)

sndLens :: Lens (a, b) b
sndLens = Lens snd $ \x (a, b) -> (a, x)

镜头真正的便利之处在于它们的组成:

compose :: Lens b c -> Lens a b -> Lens a c
compose f g = Lens (getter f . getter g) $
                   \c a -> setter g (setter f c (getter g a)) a

它们会自动转换为状态转换:

lensGet :: MonadState s m => Lens s a -> m a
lensGet = gets . getter

lensSet :: MonadState s m => Lens s b -> b -> m ()
lensSet f = modify . setter f

lensMod :: MonadState s m => Lens s b -> (b -> b) -> m ()
lensMod f g = modify $ setter f =<< g . getter f

(+=) :: (MonadState s m, Num b) => Lens s b -> b -> m ()
f += x = lensMod f (+ x)

关于haskell - 功能性镜片,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8307370/

相关文章:

haskell - 是否有类似 runDB 但在 Handler monad 之外的东西?

Haskell - 搜索元组列表,返回第二个元素

haskell - 如何实现纯函数式标准二进制堆(ocaml 或 haskell)?

haskell - 在整数列表中搜索,按增长排序的最长有序子集(不一定是连续的)之一

javascript - 合并两个不同形状的数据结构

haskell - 评估部分应用功能

haskell - 关于在类 Haskell 语言中通过部分应用定义 "multivariable"函数

javascript - 如何从 Crocks javascript 库中的 Monads 中提取值

scala - 使用另一个属性的值修改带有 Monocle 镜头的属性

haskell - 如何制作具有类型系列的记录镜头