免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 6239 | 回复: 10
打印 上一主题 下一主题

fmap如何使用? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-05-05 08:35 |只看该作者 |倒序浏览
Prelude> :i fmap
class Functor f where fmap :: (a -> b) -> f a -> f b

Prelude> fmap (+1) [1,2,3]
[2,3,4]
Prelude> map (+1) [1,2,3]
[2,3,4]

好像与map没什么区别 ?

[ 本帖最后由 sw2wolf 于 2009-5-5 09:03 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2009-05-05 09:12 |只看该作者

回复 #1 sw2wolf 的帖子

你可以到 Prelude 模块中找到 fmap 在不同类型 instance Functor 代码的定义

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
3 [报告]
发表于 2009-05-05 09:51 |只看该作者
原帖由 sw2wolf 于 2009-5-5 08:35 发表
Prelude> :i fmap
class Functor f where fmap :: (a -> b) -> f a -> f b

Prelude> fmap (+1) [1,2,3]
[2,3,4]
Prelude> map (+1) [1,2,3]
[2,3,4]

好像与map没什么区别 ?

对于 [] 来说,fmap 和 map 确实没有什么区别。

论坛徽章:
0
4 [报告]
发表于 2009-05-05 14:52 |只看该作者
-- Given a window, find the screen it is located on, and compute
-- the geometry of that window wrt. that screen.
floatLocation :: Window -> X (ScreenId, W.RationalRect)

--.......
rr <- snd `fmap` floatLocation w
--....

这里的fmap如何理解呢?

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
5 [报告]
发表于 2009-05-05 16:25 |只看该作者
原帖由 sw2wolf 于 2009-5-5 14:52 发表
floatLocation :: Window -> X (ScreenId, W.RationalRect)

--.......
rr <- snd `fmap` floatLocation w
--....

这里的fmap如何理解呢?

fmap :: (Functor f) => (a->b) -> f a -> f b

snd :: (c, d) -> d

floatLocation w 的类型为 X (ScreenId, W.RationalRect)

那么, fmap 应用到 snd 上时,会将 a 替换为 (c,d), 将 b 替换为 d, 于是 fmap snd 的类型就是 f (c, d) -> f d;在将 fmap snd 应用到 floatLocation w 上时,会把这里的 f 换为 X, (c,d) 换为 (ScreenId, W.RationalRect),就得 X (ScreenId, W.RationalRect) -> X W.RationalRect,则 fmap snd (floatLocation w) 的类型就是 X W.RationalRect

[ 本帖最后由 MMMIX 于 2009-5-5 16:38 编辑 ]

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
6 [报告]
发表于 2009-05-05 16:56 |只看该作者

回复 #5 MMMIX 的帖子

其实,fmap 做的事情,把它的类型稍微重写下,就很清楚了

  1. class Functor f where
  2.     fmap :: (a -> b) -> (f a -> f b)
复制代码

也即 fmap 会将一个类型为 a -> b 的函数转换为一个类型为 f a -> f b 的函数,其中的 f 就是 class Functor 定义中的参数 f.

论坛徽章:
0
7 [报告]
发表于 2009-05-05 19:32 |只看该作者
谢谢大家 !

原来 X 就是 f   !

fmap (+2)  [1,2,3,4]中, f是什么呢?

[ 本帖最后由 sw2wolf 于 2009-5-5 19:52 编辑 ]

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
8 [报告]
发表于 2009-05-06 12:23 |只看该作者
原帖由 sw2wolf 于 2009-5-5 14:52 发表
-- Given a window, find the screen it is located on, and compute
-- the geometry of that window wrt. that screen.
floatLocation :: Window -> X (ScreenId, W.RationalRect)

--.......
rr <- snd `fmap` floatLocation w
--....

这里的fmap如何理解呢?

看起来楼主把同样的问题在 Haskell-Cafe 中又问了一遍,其中 Thomas Davie 的回答特别精彩,地址见下
http://www.haskell.org/pipermail ... 009-May/060980.html

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
9 [报告]
发表于 2009-05-06 12:24 |只看该作者
原帖由 sw2wolf 于 2009-5-5 19:32 发表

fmap (+2)  [1,2,3,4]中, f是什么呢?

[]

论坛徽章:
0
10 [报告]
发表于 2009-05-06 19:46 |只看该作者
函子映射 functor map
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP