Hacks in Typed Racket

栏目: Lisp · 发布时间: 6年前

内容简介:Typed Racket是Racket语言的静态类型版本,使用Racket的宏独立写成,能够很好地证明racket的宏的强大。Typed Racket的设计更加偏向于与已有的Racket代码兼容而不是模仿Haskell或者Scala或者ML或者Shen的设计,它很好地做到了将untyped code与typed code的结合,每一个Type都有与之对应的contract。目前学习Typed Racket的最好教程依然是Typed Racket Guide和Typed Racket Reference,但

Typed Racket是Racket语言的静态类型版本,使用Racket的宏独立写成,能够很好地证明racket的宏的强大。Typed Racket的设计更加偏向于与已有的Racket代码兼容而不是模仿Haskell或者Scala或者ML或者Shen的设计,它很好地做到了将untyped code与typed code的结合,每一个Type都有与之对应的contract。

目前学习Typed Racket的最好教程依然是Typed Racket Guide和Typed Racket Reference,但是相信很多人看过之后依然会有一些疑问,依然会有一些不太懂的地方,毕竟这两个教程依然是比较简略的。我们这里将会补充一些关于Typed Racket的知识,充分发挥其威力,不过我建议先看上面那两个。

typed omega combinator

在typed racket中写出omega combinator需要一些技巧:

#lang typed/racket
(: omega (All (a) (-> (All (b) (-> b a)) a)))
(define (omega x)
  (x x))

细心的朋友可能注意到typed racket是天然支持RankNTypes的。

不过这个版本没有什么用处,因为(omega omega)也不能type check。

所以,我们应该这样写:

#lang typed/racket
(define-type (w-type a) (-> (w-type a) a))
(: omega w-type)
(define (omega x) (x x))
(omega omega)

完美!

Bound Qualification

同Haskell中的Bound Qualification,这里可以用intersection type实现同样的效果:

forall a.Num a=>a->a 等价于

(All (a) (-> (Intersection a Number) a))

ADT

这个写一个宏就行了:

#lang typed/racket
(require syntax/parse/define)
(define-simple-macro (define-datatype (typename:id typevars:id ...) (typecons:id [val (~literal :) types] ...) ...)
  (begin (struct (typevars ...) typecons ([val : types] ...)) ...
        (define-type typename (U typecons ...))))

(define-datatype (Bool)
  (True) (False))

(define-datatype (Maybe a)
  (Just [val : a])
  (Nothing))

inst

(map cons '(1 2 3) '(2 3 4))

(map (lambda #:forall (a) ([x : a]) x) '(1 2 3))

这样简单的函数也是没有办法成功执行的,这是因为TR的类型推倒非常辣鸡,所以你应该显式的写出多态参数:

(map (inst cons Integer Integer) '(1 2 3) '(2 3 4))

(map (inst (lambda #:forall (a) ([x : a]) x) Integer) '(1 2 3))


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

当下的冲击

当下的冲击

道格拉斯•洛西科夫 (Douglas Rushkoff) / 孙浩 赵晖 / 中信出版社 / 2013-10-1 / 59.00元

这是一个并不符合人本能的社会…… 为什么我们不应该更注重生活的质量而非速度? 为什么我们不用面对面的交流代替冷冰冰电脑屏幕上的文字代码? 为什么我们不可以选择一个虽然有缺陷但有血有肉的人类社会,而非一个虽趋于完美但冷漠的数字世界? 在当下的冲击面前,你正变得越来越弱智:你没有了自己的独特空间,你过多地相信真人秀节目,你成了数字化产品的奴隶并得了数字化精神病,你的生物钟也被打......一起来看看 《当下的冲击》 这本书的介绍吧!

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具

随机密码生成器
随机密码生成器

多种字符组合密码

URL 编码/解码
URL 编码/解码

URL 编码/解码