我想我确实理解list monad,但后来我发现我不是。这是故事。
给定列表m
和函数k
> let m = [1..10]
> :t m
m :: [Integer]
> let k = replicate 2
> :t k
k :: a -> [a]
玩绑定>>=
给出了我的期望
> :t (>>=)
(>>=) :: Monad m => m a -> (a -> m b) -> m b
> :t m >>= k
m >>= k :: [Integer]
> m >>= k
[1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10]
但对于>>
预期(从体验 IO monad,左侧的所有内容都将被丢弃)
m >> m
[1,2,3,4,5,6,7,8,9,10]
拿到
> :t (>>)
(>>) :: Monad m => m a -> m b -> m b
:t m >> m
m >> m :: [Integer]
> m >> m
[1,2,3,4,5,6,7,8,9,10,1,2,3,4,5 ... 9,10] -- truncated, real output is 100 elements
请解释为什么>>
不像我预期的那样表现(当然我一定有误解)以及正确的解释方法是>>
什么?