1. 语法糖——元组的“名称引用”与“位置引用”:

(e1,...,en) <=> {1=e1,...,n=en}

类型:t1 * … * tn <=> {1:t1,...,n:tn}

2. 自定义数据类型绑定:

datatype mytype = TwoInts of int * int

| Str of string

| Pizza

3. 访问自定义数据类型的值:

fun f x = (* f has type mytype -> int *)

case x of

Pizza => 3

| TwoInts(i1, i2) => i1 + i2

| Strs=>String.sizes

4. 数据类型绑定与Case表达式简化描述:

datatype t = C1 of t1 | C2 of t2 | … | Cn of tn

case e of p1 => e1 | p2 => e2 | … | pn => en

5. 类型别名(Type Synonyms)

type foo = int

6. 自定义列表类型

datatype my_int_list = Empty

| Cons of int * my_int_list

7. 多态类型(Polymorphic Datatypes)

datatype 'a option = NONE | SOME of 'a

二叉树定义:

datatype ('a, 'b) tree = Node of 'a * ('a, 'b) tree * ('a, 'b) tree

| Leaf of 'b

8. Val-Binding的真相——模式匹配(Pattern-Matching for Each-Of Types)

例8-1-1:

fun sum_triple (triple : int * int * int) =

case triple of

(x, y, z) => z + y + x

例8-2-1:

fun full_name (r : {first : string, middle : string, last : string}) =

case r of

{first = x, middle = y, last = z} => x ^ "" ^ y ^ "" ^ z

例8-2-2:

fun full_name (r : {first : string, middle : string, last : string}) =

let val {first = x, middle = y, last = z} = r

in

x ^ "" ^ y ^ "" ^ z

end

例8-1-2:

fun sum_triple (triple : int * int * int) =

let val (x, y, z) = triple

in

x + y + z

end

例8-2-3:

fun full_name {first = x, middle = y, last = z} =

x ^ "" ^ y ^ "" ^ z

例8-1-3:

fun sum_triple (x, y, z) =

x + y + z

9. 题外话——类型推导(Type inference)

In ML,every variable and function has a type (or your program fails to type-check)—

type inference only means you do not need to write down the type.

10. 题外话——多态类型与等价类型

'a list * 'a list -> 'a list

可以替换为:string list * string list -> string list

不能替换为:string list *int list -> string list

'a 必须替换为同样的数据类型

11. 嵌套模式(Nested Patterns)

a::(b::(c::d))    包含至少3个元素的list

a::(b::(c::[])) 只包含3个元素的list

模式匹配的递归定义(the elegant recursive denition of pattern matching)

1

A variable pattern(x) matches any value v and introduces one binding (from x to v).

2

The pattern C matches the value C,if C is a constructor that carries no data.

3

The pattern C p where C is a constructor and p is a pattern matches a value of the form C v (notice the constructors are the same) if p matches v (i.e., the nested pattern matches the carried value). It introduces the bindings that p matching v introduces.

4

The pattern (p1,p2,...,pn) matches a tuple value (v1,v2,...,vn) if p1 matches v1 and p2 matches v2, ..., and pn matches vn. It introduces all the bindings that the recursive matches introduce.

5

(A similar case for record patterns of the form {f1=p1, … , fn=pn} ...)

例11-1-1:

fun len xs =

case xs of

[] => 0

| x::xs' => 1 + len xs'

例11-1-2:

fun len xs =

case xs of

[] => 0

| _::xs' => 1 + len xs'

通配符(wildcard) (_) 指代任意没有定义数据类型的值

12. 可用的嵌套模式范例:

例12-1:

exception BadTriple

fun zip3 list_triple =

case list_triple of

([], [], []) => []

| (hd1::tl1, hd2::tl2, hd3::tl3) => (hd1, hd2, hd3)::zip3(tl1, tl2, tl3)

| _ => raiseBadTriple

fun unzip3 lst =

case lst of

[] => ([], [], [])

| (a, b, c)::tl => let val (l1, l2, l3) = unzip3 tl

in

(a::l1, b::l2, c::l3)

end

例12-2:

datatype sgn = P | N | Z

fun multsign (x1, x2) =

let fun sign x = if x = 0 then Z else if x > 0 then P else N

in

case(sign x1,sign x2) of

(Z, _) => Z

| (_, Z) => Z

| (P, P) => P

| (N, N) => P

| _ => N (* many say bad style; I am okay with it *)

end

13. 多重选择的函数定义(Multiple Cases in a Function Binding)

例13-1:

datatype exp = Constant of int | Negate of exp | Add of exp * exp | Multiply of exp * exp

fun eval(Constant i) = i

| eval(Negate e2) = ~(eval e2)

| eval(Add(e1, e2)) = (eval e1) + (eval e2)

| eval(Multiply(e1, e2))=(eval e1) * (eval e2)

fun append ([], ys) = ys

| append (x::xs', ys) = x::append(xs', ys)

一般形态(语法糖形式):

fun f p1 = e1

| f p2 = e2

...

| f pn = en

普通写法:

fun f x =

case x of

p1 => e1

| p2 => e2

...

| pn => en

14. 异常(Exception)

输出异常(关键字) raise:raise List.Empty

定义异常(关键字)exception:exception MyUndesirableCondition

15. 尾递归和累加器

fun sum1 xs =

case xs of

[] => 0

| i::xs' => I + sum1 xs'

16. 尾递归的定义

递归的调用出现在尾位置(saying a call is a tail call if it is in tail position.)

尾位置定义:

1

In fun f(x) = e, e is in tail position.

2

If an expression is not in tail position, then none of its sub expressions are in tail position.

3

If if e1 then e2 else e3 is in tail position, then e2 and e3 are in tail position (but not  e1).(Case-expressions are similar.)

4

If let b1 … bn in e end is in tail position,then e  is in tail position (but no expressions in the bindings are).

5

Function-call arguments are not in tail position.

Programming Language A 学习笔记(二)的更多相关文章

  1. Learning ROS for Robotics Programming Second Edition学习笔记(二) indigo tools

    中文译著已经出版,详情请参考:http://blog.csdn.net/ZhangRelay/article/category/6506865 Learning ROS for Robotics Pr ...

  2. SQL Expression Language Tutorial 学习笔记二

    11. Using Textual SQL 直接使用 SQL 如果实在玩不转, 还是可以通过 test() 直接写 SQL. In [51]: s = text( ...: "SELECT ...

  3. Programming Language A 学习笔记(一)

    SML(一) 1. ML是一个函数式编程语言,理论基础为λ演算. 2. 变量声明 val x = e; 标准类型:单元(unit).布尔(bool).整型(int).字符串(string).实数(re ...

  4. 《The C Programming Language》学习笔记

    第五章:指针和数组 单目运算符的优先级均为2,且结合方向为自右向左. *ip++; // 将指针ip的值加1,然后获取指针ip所指向的数据的值 (*ip)++; // 将指针ip所指向的数据的值加1 ...

  5. AJax 学习笔记二(onreadystatechange的作用)

    AJax 学习笔记二(onreadystatechange的作用) 当发送一个请求后,客户端无法确定什么时候会完成这个请求,所以需要用事件机制来捕获请求的状态XMLHttpRequest对象提供了on ...

  6. 转)delphi chrome cef3 控件学习笔记 (二)

    (转)delphi chrome cef3 控件学习笔记 (二) https://blog.csdn.net/risesoft2012/article/details/51260832 原创 2016 ...

  7. WPF的Binding学习笔记(二)

    原文: http://www.cnblogs.com/pasoraku/archive/2012/10/25/2738428.htmlWPF的Binding学习笔记(二) 上次学了点点Binding的 ...

  8. [Firefly引擎][学习笔记二][已完结]卡牌游戏开发模型的设计

    源地址:http://bbs.9miao.com/thread-44603-1-1.html 在此补充一下Socket的验证机制:socket登陆验证.会采用session会话超时的机制做心跳接口验证 ...

  9. JMX学习笔记(二)-Notification

    Notification通知,也可理解为消息,有通知,必然有发送通知的广播,JMX这里采用了一种订阅的方式,类似于观察者模式,注册一个观察者到广播里,当有通知时,广播通过调用观察者,逐一通知. 这里写 ...

随机推荐

  1. Linux 系统命令

    1.ctrl+z 让正在运行的任务暂停运行, 然后可用 bg %jobId使之后台运行,相当于: 命令 & 2. jobs -l 查看任务 3. echo $$ 查看当前进程 4.nohup ...

  2. Fedora下依赖库的解决

    转载于http://blog.sina.com.cn/s/blog_6f74890d0101dpp4.html x86_64版本的fedora中打开共享对象文件失败的解决小技巧———以qq for l ...

  3. SQL Server中查询数据库及表的信息语句

    /* -- 本文件主要是汇总了 Microsoft SQL Server 中有关数据库与表的相关信息查询语句. -- 下面的查询语句中一般给出两种查询方法, -- A方法访问系统表,适应于SQL 20 ...

  4. js的DOM的方法和属性总结

    1.DOM的获取元素document.getElementById()context.getElementsByTagName(tag) (可以获取相应上下文环境所有的tag标签)context.ge ...

  5. Linux时间同步

    (1)进入 root权限 su root(2)使用ntpdate IP(时间源IP)或service crond restart查看服务有没有开启(3)#crontab -e(新增一下语句) 0 */ ...

  6. angularJS实践过程中出现的问题总结

    同名服务 在一次项目里,之前是同事写的.我有一次在异步获取服务器上的数据时,习惯把api地址写在一个服务Store里,但是程序总是返回Store.api.get()里的get is undefined ...

  7. canvas简介

    一.canvas简介 1.1 什么是canvas?(了解) 是HTML5提供的一种新标签 <canvas></canvas> 英 ['kænvəs] 美 ['kænvəs] 帆 ...

  8. kali python pip3 的安装和卸载

    今天很高兴安装完成调整了kali 然后看见kali已经帮助我安装了python2.7和python3.5可把我开心坏了,可是2.7有pip,而且包很全,但2.7与3.0切换使用我的就尴尬了 最后在su ...

  9. asp:Repeater实例备忘

    1.前置部分 <asp:Repeater ID="rptPlanNo" runat="server" OnItemDataBound="rptP ...

  10. css3中变形函数(同样是对元素来说的)和元素通过改变自身属性达到动画效果

    /*对元素进行改变(移动.变形.伸缩.扭曲)*/ .wrapper{ margin:100px 100px auto auto; width:300px; height:200px; border:2 ...