Lisp,Haskell,Erlang的Lambda演算的区别
这个问题我也很难提问,但还是尝试来了解一些未知的知识;
对Lambda
的演算还不熟悉,看过一些分散的资料,wikipedia上的,还有一些人写的blog。
但是没发现Lisp,Haskell,Erlang的Lambda演算介绍,以及他们各自的区别。
see also: http://mindhacks.cn/2006/10/15/cantor-godel-turing-an-eternal-golden-diagonal/
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
什么是Lambda演算?
Lambda calculus是基于函数定义与运用的一门系统数学,以极简化的方式表达和运用函数。在计算机理论中λ-calculus具备图灵完全性,是Functional Programing的基础框架。在(注重实用的)编程语言中,Lambda通指不具名的函数表达式。
数学中λ-calculus的表示法为:
1. λx.t
2. λx[t]
“λ”不具有任何特殊意思,标识着其表达式中的可取一数值x带入。
t是表达式(例如x+3、x^2+2x+1等)。
代入数值p的表示法为:
1. (λx.t)p
2. (λx[t])p
Lisp,Haskell,Erlang的Lambda演算
以f(x)=x+1 为参照:
Lisp的λ表示法与数值代入:
Erlang:
Haskell: