programming-languages学习笔记--第10部分
programming-languages学习笔记–第10部分
*/-->
pre.src {background-color: #292b2e; color: #b2b2b2;}
pre.src {background-color: #292b2e; color: #b2b2b2;}
pre.src {background-color: #292b2e; color: #b2b2b2;}
pre.src {background-color: #292b2e; color: #b2b2b2;}
pre.src {background-color: #292b2e; color: #b2b2b2;}
pre.src {background-color: #292b2e; color: #b2b2b2;}
pre.src {background-color: #292b2e; color: #b2b2b2;}
pre.src {background-color: #292b2e; color: #b2b2b2;}
pre.src {background-color: #292b2e; color: #b2b2b2;}
pre.src {background-color: #292b2e; color: #b2b2b2;}
pre.src {background-color: #292b2e; color: #b2b2b2;}
pre.src {background-color: #292b2e; color: #b2b2b2;}
pre.src {background-color: #292b2e; color: #b2b2b2;}
pre.src {background-color: #292b2e; color: #b2b2b2;}
programming-languages学习笔记–第10部分
目录
1 Subtyping
- 伪代码表示:
创建record: {f1=e1, f2=e2, …, fn=en},
字段访问:e.f,字段更新:e1.f=e2
基本的类型系统:
{f1:t1, f2:t2, …, fn:tn}
a:{x:real, y:real}与类型
b:{x:real, y:real, color:string}不同,但是可以在接受第一种类型的地方使用第二种类型。
让使用a的地方用b代替通过类型检查。就是Subtyping。
2 子类关系
保持subtyping独立,一个编程语言已经有很多类型规则,不去修改它们,只增加subtyping。
用t1 <: t2(类型间的二元关系)表示t1是t2的子类型,如果e拥有类型t1并且t1 <: t2,则e也拥有类型t2。
如果t1 <: t2,则t1类型的任何值都可以用在t2可以使用的地方。
3 Depth Subtyping
深度子类化:
{center:{x:real,y:real,z:real}, r:rael} <:
{center:{x:real,y:real}, r:real}
如果要让这个子类化成立,则需要添加规则,
if ta <: tb then {f1:t1,…,f:ta,…,fn:tn} <:
{f1:t1,…,f:tb,…,fn:tn}
但是它破坏了可靠性(soundness),可以访问不存在的字段。
如果字段是不可变的,则深度子类化是可靠的,只能从3个里面选2个:setters,depth subtyping, soundness。
4 Function Subtyping
函数类型,在higher-order函数中,参数可以用使用t3->t4代替t1->t2么?
函数返回值是可以的:
if ta <: tb then t->ta <: t->tb
函数返回值是协变(covariant)的。
函数参数不可以:
ta <: tb 不允许 ta->t <: tb->t,
相反的情况可以:
if tb <: ta then ta->t <: tb->t,
参数类型是逆变(contravariant)的。
可以综合起来:
if t3 <: t1 and t2 <: t4, then t1->t2 <: t3->t4。
参数是逆边,返回值是协变。
5 OOP中的子类化
子类关系就是子类型关系。
一个对象就是包含字段和方法的记录:
- 可变字段
- 方法是可变函数,并且可以访问self
可以设计一个像记录类型的类型系统:
- 子类型可以有额外的字段和方法
- 覆盖方法需要逆变参数和协变返回值,与函数子类化相似。
self/this是特殊的,虽然是函数参数,但它是协变的。子类中的方法只能使用子类可用的字段和方法。
6 泛型对比子类化
在ML中:
fun compose (g,h) = fn x => g (h x)
(* val compose = fn : ('a -> 'b) * ('c -> 'a) -> 'c -> 'b *)
子类化不适合这样的操作,作为容器不方便。
需要做downcast,并且需要运行时开销。
子类化适用于表示几何,GUI等。
7 Bounded Polymorphism
结合泛型和子类化,就是有界多态。
作者: ntestoc
Created: 2019-01-09 三 13:31
programming-languages学习笔记--第10部分的更多相关文章
- 【python学习笔记】10.充电时刻
[python学习笔记]10.充电时刻 任何python都可以作为模块倒入 *.pyc:平台无关的经过编译的的python文件, 模块在第一次导入到程序中时被执行,包括定义类,函数,变量,执行语句 可 ...
- Java程序猿的JavaScript学习笔记(10—— jQuery-在“类”层面扩展)
计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...
- Linux学习笔记(10)linux网络管理与配置之一——主机名与IP地址,DNS解析与本地hosts解析(1-4)
Linux学习笔记(10)linux网络管理与配置之一——主机名与IP地址,DNS解析与本地hosts解析 大纲目录 0.常用linux基础网络命令 1.配置主机名 2.配置网卡信息与IP地址 3.配 ...
- SpringBoot学习笔记(10):使用MongoDB来访问数据
SpringBoot学习笔记(10):使用MongoDB来访问数据 快速开始 本指南将引导您完成使用Spring Data MongoDB构建应用程序的过程,该应用程序将数据存储在MongoDB(基于 ...
- Flutter学习笔记(10)--容器组件、图片组件
如需转载,请注明出处:Flutter学习笔记(10)--容器组件.图片组件 上一篇Flutter学习笔记(9)--组件Widget我们说到了在Flutter中一个非常重要的理念"一切皆为组件 ...
- javaSE学习笔记(10)---List、Set
javaSE学习笔记(10)---List.Set 1.数据存储的数据结构 常见的数据结构 数据存储的常用结构有:栈.队列.数组.链表和红黑树. 1.栈 栈:stack,又称堆栈,它是运算受限的线性表 ...
- Ionic2学习笔记(10):扫描二维码
作者:Grey 原文地址: http://www.cnblogs.com/greyzeng/p/5575843.html 时间:6/11/2016 说明: 在本文发表的时候(2016-06-1 ...
- Git学习笔记(10)——搭建Git服务器
本文主要记录了Git服务器的搭建,以及一些其他的配置,和最后的小总结. Git远程仓库服务器 其实远程仓库和本地仓库没啥不同,远程仓库只是每天24小时开机为大家服务,所以叫做服务器.我们完全可以把自己 ...
- Deep learning with Python 学习笔记(10)
生成式深度学习 机器学习模型能够对图像.音乐和故事的统计潜在空间(latent space)进行学习,然后从这个空间中采样(sample),创造出与模型在训练数据中所见到的艺术作品具有相似特征的新作品 ...
随机推荐
- nginx为什么性能这么优越?
Nginx (“engine x”) 是一个高性能的 HTTP 和 反向代理 服务器 ,也是一个 IMAP/POP3/SMTP 代理 服务器 . Nginx 是由 Igor Sysoev 为俄罗斯访问 ...
- Linux CPU使用率的计算
CPU 使用率衡量的是程序运行占用的CPU 百分比.Linux 的CPU 使用率信息可以通过/proc/stat 文件计算得到. proc 文件系统 /proc 文件系统是一个伪 ...
- 有趣:256个class选择器可以干掉1个id选择器——张鑫旭
我们应该都知道,从选择器得分权重上将,id选择器(#aaa{})和class选择器(.aaa{})完全不是一个数量级的,前者:1-0-0; 而后者为0-1-0.因此: #id { color:dark ...
- 使用JavaScript动态更改CSS样式
在很多情况下,都需要对网页上元素的样式进行动态的修改.在JavaScript中提供几种方式动态的修改样式,下面将介绍方法的使用.效果.以及缺陷. 1.使用obj.className来修改样式表的类名. ...
- CSS实现跨浏览器兼容性的盒阴影效果
.shadow { -moz-box-shadow: 3px 3px 4px #000; -webkit-box-shadow: 3px 3px 4px #000; box-shadow: 3px 3 ...
- 安装php扩展redis (windows环境)
首先十分感谢网络上支持开源分享的前辈们,资源真的太丰富了,虽然也有许多优秀的国外资源被墙了... 想要给php增加redis扩展第一步当然要知道自己使用的php版本以及一些配置.查看 phpinfo ...
- opencv3.2.0形态学滤波之形态学梯度、顶帽、黑帽
/*一.形态学梯度 (1)含义:是膨胀图和腐蚀图之差 (2)数学表达式:dst=morph-grad(src,element) =dilate(src,element) - erode(src,ele ...
- Windows win7下VMware Virtual Ethernet Adapter未识别网络解决方法
win7下VMware Virtual Ethernet Adapter未识别网络解决方法[摘] by:授客 QQ:1033553122 问题描述 win7系统下安装VMware,查看网卡适配器设置, ...
- iphone使用linux命令apt-get也没有问题
那么教程开始: 首先安装cydia这个越了yu就有自带的哦 然后添加源,比如apt.91.我忘了,大家可以在http://frank-dev-blog.club/?post=45找一个 查找termi ...
- 深入理解net core中的依赖注入、Singleton、Scoped、Transient(四)
相关文章: 深入理解net core中的依赖注入.Singleton.Scoped.Transient(一) 深入理解net core中的依赖注入.Singleton.Scoped.Transient ...