网站大量收购独家精品文档,联系QQ:2885784924

重载与类型分类OverloadingandTypeClasses.pptVIP

  1. 1、本文档共19页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
重载与类型分类OverloadingandTypeClasses

重载与类型分类 Overloading and Type Classes 重载 为什么使用重载 为什么使用重载 类型分类Classes 定义类 特例 例 函数elem 缺省定一 子类 多重约束 基本类 可显示类 可读类 有序类 Num – 数值类 多态函数与重载 * 什么是重载? 类型分类的概念 签名与特例 运算符 (+) 可以用于计算两个相同类型数值之和: 1 + 2 3 1.2 + 1.1 3.3 我们称运算符(+)被重载:(+)可用于不同的类型,但是,它在不同类型上的定义不同。 假设我们要定义一个函数检查一个元素是否出现在一个布尔值列表中: elemBool :: Bool - [Bool] - Bool elemBool x [] = False elemBool x (y:ys) = (x == y || elemBool x ys) 如果我们想定义一个函数检查一个元素是否出现在一个整数列表中: elemInt :: Int - [Int] - Bool 在这里重复上述定义,只是将布尔类型上的相等运算替换为整数类型上的相等即可。 Bool上的相等 在这种情况下,我们希望定义一个下列类型的函数: elem :: a - [a] - Bool elem x [] = False elem x (y:ys) = (x == y || elem x ys) 条件是类型a上定义了相等运算 (==) 。 Haskell 使用类型分类系统实现上述需求。 一个类型分类或者类(class)是支持某些重载运算的类型的集合,这些运算又称为类的方法。 例如,定义了相等运算和不相等运算的类型的集合称为Eq(相等类),两个运算记作 (==) :: a - a - Bool (/=) :: a - a - Bool Eq类的定义是: class Eq a where (==) :: a - a - Bool (/=) :: a - a - Bool class Visible a where toString :: a - String size :: a - Int 类名 签名:运算名及其类型 一个类的成员称为一个特例。Eq的特例包括基本类型Int, Float, Bool, Char. 将一个类型定义为一个类的特例的方法是:通过使用instance 特例说明语句并定义类的方法。例如,说明Bool是Eq的特例: instance Eq Bool where True == True = True False == False = True _ == _ = False x /= y = not (x == y) 定义Bool是Visible的特例: instance Visible Bool where toString True = “True” toString False = “False” size _ = 1 返回函数elem的例子,我们希望其类型是: elem :: a - [a] - Bool 其中类型a上定义了相等,或者说类型a是类Eq的特例。这样的要求可以在Haskell中如下说明: elem :: Eq a = a - [a] - Bool 函数的定义保持不变: elem x [] = False elem x (y:ys) = (x == y || elem x ys) 一个带有约束的类型称为重载类型,具有重载类型的函数称为重载函数。 约束 一个类的方法可以有缺省定义,缺省定义可以被特例定义覆盖。 例如,Eq类定义如下: class Eq a where (==), (/=) :: a - a - Bool x /= y = not (x == y) x == y = not (x /= y) 缺省定义 一个类可能依赖于另一个类。例如,类Ord包含那些可以比较其值的类型。一个属于类Ord的类型不仅支持相等运算,而且支持比较运算, =等。为此,定义 class Eq a = Ord a where (), (=), (), (=) :: a - a - Bool max, min :: a - a - a compare :: a - a - Ordering Ord 是 Eq的子类

文档评论(0)

118books + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档