免费注册 查看新帖 |

Chinaunix

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

Haskell 中的模式绑定 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-04-28 19:19 |只看该作者 |倒序浏览
Haskell 可以这样绑定,一举三得
  1. Prelude> let xss@(x:xs) = [1, 2, 3, 4]
  2. Prelude> xss
  3. [1,2,3,4]
  4. Prelude> x
  5. 1
  6. Prelude> xs
  7. [2,3,4]
复制代码

以前一直认为这种写法只是用在 pattern match 中呢 ?没想到直接绑定也可以

python 中有一种写法:
  1. >>> point = x, y = 1, 2
  2. >>> point
  3. (1, 2)
  4. >>> x
  5. 1
  6. >>> y
  7. 2
复制代码
在 Haskell 中类似的一种写法:
  1. Prelude> let point@(x, y) = (1, 2)
  2. Prelude> point
  3. (1,2)
  4. Prelude> x
  5. 1
  6. Prelude> y
  7. 2
复制代码
再推广一下:
除了常量、字符串外,任何其他 pattern matching 形式都可以被用到 Variables Binding 中
pattern 几种形式请参考帖子:>>>Haskell语法参考(点击此处)<<<7. Patterns(模式)

  1. Prelude> let x = 1                                --name
  2. Prelude> x
  3. 1
  4. Prelude> let _ = 1                                -- _ 虽然这个语法正确,但不产生任何作用
  5. Prelude> let (x, y, z) = (1, 2, 3)             -- (pat1, pat2 ... , patn)
  6. Prelude> x
  7. 1
  8. Prelude> y
  9. 2
  10. Prelude> z
  11. 3
  12. Prelude> let x:xs = [1, 2, 3]                  --pat1:pat2
  13. Prelude> x
  14. 1
  15. Prelude> xs
  16. [2,3]
  17. Prelude> let [_, x, y] = [1, 2, 3]
  18. Prelude> x
  19. 2
  20. Prelude> y
  21. 3
  22. Prelude> let 'a':'b':'c':x:xs = "abcdefg"
  23. Prelude> x
  24. 'd'
  25. Prelude> xs
  26. "efg"
  27. Prelude> let points@[point1, point2, point3] = [(1, 2), (3, 4), (4, 5)]                 --name@pat
  28. Prelude> points
  29. [(1,2),(3,4),(4,5)]
  30. Prelude> point1
  31. (1,2)
  32. Prelude> point2
  33. (3,4)
  34. Prelude> point3
  35. (4,5)
复制代码

[ 本帖最后由 izhier 于 2009-5-1 19:12 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2009-04-28 20:44 |只看该作者
一个经典的用法是 scanr 函数的定义:

  1. scanr               :: (a -> b -> b) -> b -> [a] -> [b]
  2. scanr f q0 []       = [q0]
  3. scanr f q0 (x:xs) = f x q : qs
  4.                           where qs@(q:_) = scanr f q0 xs
复制代码

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
3 [报告]
发表于 2009-04-28 21:02 |只看该作者
纠正一下,Haskell 中并没有“赋值”,
你所说的【以前一直认为这种写法只是用在 pattern match 中呢】真是对极了,
let xss@(x:xs) = [1, 2, 3, 4] 正就是模式匹配。

论坛徽章:
0
4 [报告]
发表于 2009-04-28 21:52 |只看该作者
原帖由 flw 于 2009-4-28 21:02 发表
纠正一下,Haskell 中并没有“赋值”,

嗯,应该叫 Variables Bindings
我改过来

论坛徽章:
0
5 [报告]
发表于 2009-04-28 21:56 |只看该作者
原帖由 flw 于 2009-4-28 21:02 发表
let xss@(x : xs) = [1, 2, 3, 4] 正就是模式匹配。

这个倒是没在书上看到过
书上说是 Let Bindings
如果在代码中,应该是 Bindings

应该是其中用到了 pattern,没有 matching(比较) 的含义吧
pattern matching (比较) 用在函数中来选择某一分支吧 ?

[ 本帖最后由 izhier 于 2009-4-28 22:02 编辑 ]

论坛徽章:
0
6 [报告]
发表于 2009-04-28 22:05 |只看该作者
找到了,这个形式应该叫模式绑定
在 >>>Haskell语法参考(点击此处)<<< 中的2. Pattern bindings(模式绑定)

竟然把它给忘了
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP