递归类型
维基百科,自由的百科全书
在计算机编程语言中,递归类型是一种特殊的数据类型,它表示自身内部可能包含其它的同样类型的值。
data List a = Nil | Cons a (List a)
这表示a的链表s可以是一个空表或一个cons单元包含了一个'a'(链表的“头”)和另一个链表(“尾”)。
递归不允许在Miranda语言中和Haskell的同义类型中出现,所以以下的Haskell类型是非法的:
type Bad = (Int, Bad) type Evil = Bool -> Evil
相反地,表面上是相等的代数数据类型却是可以的:
data Good = Pair Int Good data Fine = Fun (Bool->Fine)
本文參考素材源自「FOLDOC」,在GFDL下授權。 This article was originally based on material from the Free On-line Dictionary of Computing and is used under the GFDL. |