[英]Mapping `apply` to List of Functions
了解一个Haskell演示了currying的映射:
*Main> let xs = map (*) [1..3]
xs现在等于[(1 *),(2 *),(3 *)]
按照Antal SZ的评论编辑纠正订单。
我们可以获得列表中的第一项,并应用3 - 返回3 * 1。
*Main> (xs !! 0) 3
3
但是,如何应用下面的foo
将1
应用于xs
所有curried函数?
*Main> let foo = 1
*Main> map foo xs
<interactive>:160:5:
Couldn't match expected type `(Integer -> Integer) -> b0'
with actual type `Integer'
In the first argument of `map', namely `foo'
In the expression: map foo xs
In an equation for `it': it = map foo xs
期望的输出:
[1, 2, 3]
使用($)
函数...
Prelude> :t ($)
($) :: (a -> b) -> a -> b
......只传递第二个参数。
Prelude> let foo = 2
Prelude> map ($ foo) [(1*), (2*), (3*)]
[2,4,6]
你尝试过使用applicative functor吗?
import Control.Applicative
main = (*) <$> [1,2,3] <*> pure 1
<$>
函数与中缀形式的fmap
相同。 它有类型签名:
(<$>) :: Functor f => (a -> b) -> f a -> f b
<*>
函数是$
(函数应用程序)的仿函数:
(<*>) :: Applicative f => f (a -> b) -> f a -> f b
pure
函数类似于monad的return
。 它需要一个正常值并返回一个applicative functor:
pure :: Applicative f => a -> f a
因此,表达式(*) <$> [1,2,3] <*> pure 1
类似于将(*)
函数应用于[1,2,3]
和pure 1
所有值。 由于pure 1
仅有一个值,因此相当于将列表中的每个项目乘以1
以生成新的产品列表。
或者您可以使用匿名函数:
map (\x -> x foo) xs
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.