首页 >
Haskell
✍ dations ◷ 2025-01-22 23:36:14 #Haskell
Haskell(发音为/ˈhæskəl/)是一种标准化的,通用的纯函数编程语言,有非限定性语义和强静态类型。它的命名源自美国逻辑学家哈斯凯尔·加里,他在数理逻辑方面上的工作使得函数式编程语言有了广泛的基础。在Haskell中,“函数是第一类对象”。作为一门函数编程语言,主要控制结构是函数。Haskell语言是1990年在编程语言Miranda的基础上标准化的,并且以λ演算为基础发展而来。这也是为什么Haskell语言以希腊字母“λ”(Lambda)作为自己的标志。Haskell具有“证明即程序、命题为类型”的特征。1985年,Miranda发行后,惰性函数式语言的关注度增长。到1987年前,出现了十多种非限定性、纯函数式语言。其中,Miranda使用的最为广泛,但还没有出现在公共领域。在俄勒冈波特兰的函数式编程语言与计算机结构大会(FPCA '87)上,参加者一致同意形成一个委员会来为这样的语言定义一种开放性标准。该委员会旨在集成已有函数式语言,作为将来的函数式语言设计研究工作的基础。1990年定义了Haskell的第一个版本(“Haskell 1.0”)。委员会形成了一系列的语言定义(1.0,1.1,1.2,1.3,1.4)。1997年底,该系列形成了Haskell 98,旨在定义一个稳定、最小化、可移植的语言版本以及相应的标准库,以用于教学和作为将来扩展的基础。委员会明确欢迎创建各种增加或集成实验性特性的Haskell 98的扩展和变种。1999年2月,Haskell 98语言标准公布,名为《The Haskell 98 Report》。2003年1月,《Haskell 98 Language and Libraries: The Revised Report》公布。接着,Glasgow Haskell Compiler (GHC)(英语:Glasgow Haskell Compiler)实现了当时的事实标准,Haskell快速发展。2006年早期,开始了定义Haskell 98标准后续的进程,非正式命名为Haskell Prime。这是个修订语言定义的不断增补的过程,每年产生一个新的修订版。第一个修订版于2009年11月完成、2010年7月发布,称作Haskell 2010。Haskell 2010加入了外部函数接口(Foreign Function Interface(英语:Foreign Function Interface),FFI)允许绑定到其它编程语言,修正了一些语法问题(在正式语法中的改动)并废除了称为“n加k模式”(换言之,不再允许形如fact (n+1) = (n+1) * fact n的定义)。引入了语言级编译选项语法扩展(Language-Pragma-Syntax-Extension),使得在Haskell源代码中可以明确要求一些扩展功能。Haskell 2010引入的这些扩展的名字是DoAndIfThenElse、HierarchicalModules、EmptyDataDeclarations、FixityResolution、ForeignFunctionInterface、LineCommentSyntax、PatternGuards、RelaxedDependencyAnalysis、LanguagePragma、NoNPlusKPatterns。Haskell是现有的一门开放的、已发布标准的,且有多种实现的语言。支持惰性求值、模式匹配、列表解析、类型类和类型多态。它是一门纯函数编程语言,这意味着大体上,Haskell中的函数没有副作用。Haskell用特定的类型来表达副作用,该类型与函数类型相互独立。纯函数可以操作并返回可执行的副作用的类型,但不能够执行它们,只有用于表达副作用的类型才能执行这些副作用,Haskell以此表达其它语言中的非纯函数。Haskell拥有一个基于Hindley-Milner类型推论的静态、强类型系统。Haskell在此领域的主要创新就是加入了类型类(type class),原本设想作为重载的主要方式,在之后发现了更多用途。Haskell的主要实现GHC(英语:Glasgow Haskell Compiler)是个解释器,也是个原生代码编译器。它可以在大多数平台运行,GHC在并发和并行上具有高性能的实现能力,也有丰富的类型系统,如广义代数数据类型和类型族(Type Families)。单子是一个抽象类型,可以表达不同种类的计算,包括异常处理、非确定性、语法分析以及软件事务内存,其中一个应用是用于表达副作用的类型。单子定义为普通的数据类型,同时Haskell也为其提供了几种语法糖。Haskell有一个活跃的社区,在线上包仓库Hackage上有丰富的第三方开源库或工具。Haskell是强类型语言。
Char的字面值用单引号围起;
字符串即类型,其字面值用双引号括起来。
Int通常为32位整型
Integer是无界整型
Float 表示单精度的浮点数
Double 表示双精度的浮点数
Bool 只有两种值:True 和 False。使用与逗号分隔符,定义一个list的实例。其元素必须具有相同类型。字符串是list的特例。用:把元素与list、其他元素连接(cons)起来。:是右结合的运算符。 实际上是 1:2:3: 的语法糖。两个 List 合并通过 ++ 运算符实现。按照索引获取 List 中的元素,可以使用 !! 运算符,索引的下标为 0。List 中的 List 可以是不同长度,但必须得是相同的型别。这样的Range方法快捷定义一个List。用法给出了Range的第一、第二、最后一个元素。使用 > 和 >= 可以比较 List 的大小。它会先比较第一个元素,若它们的值相等,则比较下一个,以此类推。List常用的函数:list comprehension是指基于一个List,按照规则产生一个新List,例如:, x*2 >= 12]使用( )与逗号分隔符,定义一个tuple的实例。其元素可以使不同类型,但个数是固定的。Tuple的类型取决于其中项的数目与其各自元素的类型。单元素的 Tuple 被禁止。基本类似于C语言。但使用not表示逻辑非。基本的 Typeclass:if then else是分段函数定义时的语法糖。与C语言不同,要求必须有else部分。类似于C语言分支语句的情形,叫做pattern matching,例子如下:多态类型(Polymorphic types)类似于C++的模板。例如,算术加法:lambda 就是匿名函数。写法是:一个 (因为它看起来像是希腊字母λ),后面是用空格分隔的参数,-> 后面是函数体。通常用括号将括起lambda函数,否则它会占据整个右边部分。例如:(a b -> (a * 30 + 3) / b)可以在 lambda 中使用模式匹配,但无法为一个参数设置多个模式,如 和 (x:xs)并用。使用 lambda 可以更明确地表现出值是个函数,可以用来传递给其他函数作参数。Haskell的所有函数实际上是单参数函数。多参数函数的写法实际上是Curry化的语法糖。即 func a b等价于(func a) bpoint free style (也称作 pointless style) 的函数,即通过柯里化 (Currying)省略掉单参数。例如:中缀运算符可以加括号变为单参数函数。如 (*3) 5 的值为15。 但(-5)表示负值,所以单参数函数需要写为(subtract 5)。中缀运算符 $,可用于改变函数的调用次序,使其右边的表达式先计算出来。这可以减少一对括号使用。例如 f (g (z x)) 与 f $ g $ z x 等价。其定义是:$ 还可以将数据作为函数使用。例如:中缀运算符 . 用于函数的复合,其定义是:提供了处理异常的函数Template:Haskell/Template:Haskell/Template:Haskell/Template:Haskell.输出结果类似于 C++另外一个例子:如果仅有一个错误条件,Template:Haskell 类足够用了,确省是Haskell的 Template:Haskell class. 更复杂的出错处理用Template:Haskell 或Template:Haskell monads, 类似功能可用Template:Haskell。如下是Haskell语言的"Hello world",注意其中除最后一行外皆可省略。如下是阶乘函数的Haskell实现:它将阶乘描述成有一个基本终止情形的递归函数。这跟数学定义中对阶乘的描述很相似。事实上,Haskell中很多的代码的语法与功能都和数学一致。上面的递归函数的第一行是可选的,它描述了这个函数的类型(types)。它可以读作函数fac的类型为整数至整数(function fac has a int-to-int type)。这就是说,它以一个整型为参数,并且返回另一个整型。第二行依赖的模式匹配,是Haskell程序中一个重要的部分。注意函数的参数是用空格分隔而不是在括号中。当函数的参数是0时,它会返回整型1。对于其他的情况则尝试第三行。这是一个递归,它会一直执行只到满足基本的情形。负参数会导致无限递归,一个guard(英语:guard (computing))保证第三行不会执行负参数。"Prelude"是一个类似C中标准库的小函数集合。使用Prelude,并用无指定参数的写法,它可以改成:上面的定义接近于数学中的定义:f = g o h(参见复合函数),这并不是一个对变量赋值的语句。Haskell中可以定义高阶函数(Higher-order Function),既将函数作为一个参数来使用,也可以将函数作为结果输出,例如:这里f就是一个高阶函数,它取一个从Int到Int的函数g作为参数,输出一个从Int到Int的函数。高阶函数的使用在一些情况下将极大的简化代码。
相关
- 对称性数学上,若对所有的 a 和 b 属于 X,下述语句保持有效,则集合 X 上的二元关系 R 是对称的:“若 a 关系到 b,则 b 关系到 a。”数学上表示为:例如:“和……结婚”是对称关系;“小于”不
- 副溶血弧菌肠炎弧菌(学名:Vibrio parahaemolyticus),又称为副溶血弧菌,属于弧菌属,是一种常见的病原菌。肠炎弧菌是一种嗜盐性的革兰氏阴性菌,主要的栖息地在海水中。如果食用了遭此菌污染的
- 农药农药,根据美国环保署的定义,是指任何能够预防、摧毁、驱逐或减轻害虫的物质或混合物。害虫通常指与人类竞争食物,破坏财产,散播疾病或造成困扰的生命体,包括昆虫、植物病原体、杂
- 汉越词陶文 ‧ 甲骨文 ‧ 金文 ‧ 古文 ‧ 石鼓文籀文 ‧ 鸟虫书 ‧ 篆书(大篆 ‧ 小篆)隶书 ‧ 楷书 ‧ 行书 ‧ 草书漆书 ‧ 书法 ‧ 飞白书笔画 ‧
- 漱口药水漱口水,又称为口腔漱洗液,是口腔卫生产品,具有杀除微生物牙垢的功能,并防止由其引起的龋齿、齿龈炎和口臭的功效。防蛀漱洗液通过使用氟化物,从而保护牙齿并防止龋齿。漱口水也有
- 语言的起源语言的起源是一个有高度争议性的话题,由于可得到的实证证据的欠缺,许多人认为严肃的学者不应涉足于此问题。1866年,巴黎语言学会(法语:Société de linguistique de Paris)甚至明
- 氦融合氦聚变是核聚变的一种,参与此一反应的原子核是氦。这种由氦4(α粒子)融合的反应就是所谓的是3氦过程(3α过程),因为这项反应先由两个氦核聚变成为铍 8,但是这种同位素很不稳定,半衰
- 翁布里亚翁布里亚(意大利语:Umbria,意大利语发音:),位于意大利中心,首府佩鲁贾。面积8,456平方公里——其中佩鲁贾省(Perugia)6,334平方公里;特尔尼省(Terni)2,122平方公里——是意大利面积第五
- 穆斯林的无知《穆斯林的无知》(英语:Innocence of Muslims),又译《天真穆斯林》,曾名为《沙漠战士》或《本拉登的无知》,是2012年出品的一部关于伊斯兰教创始人穆罕默德其人其事的反伊斯兰教电
- 胆汁酸胆汁酸,英文是bile acids,缩写为BA,为胆汁的主要有机成分,是几种结构类似的类固醇酸的统称。在人类的胆汁中,结合型胆汁酸是主要的存在形式,在胆汁的pH环境下,几乎均以钠盐或钾盐的