您的位置:首页 > 其它

Haskell语言学习笔记(12)Data.Function

2017-02-26 23:38 435 查看

Data.Function

本文的主题是 Data.Function 这个模块。这个模块包含很多组合子(combinator)。

id

返回自身的函数。原来不做任何事也是一个函数。
id :: a -> a
id x = x

const

返回固定值的函数。
const :: a -> b -> a
const x _ = x
Prelude> map (const 42) [0..3]
[42,42,42,42]

flip

交换某个函数的两个操作数的函数。
flip :: (a -> b -> c) -> b -> a -> c
flip f x y = f y x

(&)

反向应用函数的函数。
(&) :: a -> (a -> b) -> b
x & f = f x
-- 求所有小于10000的奇平方数的和
Prelude Data.Function> [1..] & map (^2) & filter odd & takeWhile (<10000) & sum
166650

on

替换某个“带两个相同类型参数的函数“的参数类型的函数。
on :: (b -> b -> c) -> (a -> b) -> a -> a -> c
(.*.) `on` f = \x y -> f x .*. f y
Prelude Data.Function Data.List> sortBy (compare `on` fst) [(2,"abc"),(1,"def"),(3,"ghi")]
[(1,"def"),(2,"abc"),(3,"ghi")]
Prelude Data.Function> (zip `on` map fst) [(1,"abc"),(2,"def")] [(3,"abc"),(4,"def")]
[(1,3),(2,4)]
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: