这几天来,我一直在思考Haskell中的函数式编程范例。我通过阅读教程和观看视频来做到这一点,但似乎没有什么能真正坚持下来。 现在,在学习各种命令式/面向对象语言(如C、Java、PHP)时,练习对我来说是一种很好的方式。但是因为我不知道Haskell有什么能力,而且有很多新概念可以利用,所以我不知道从哪里开始。

你是怎么学会哈斯克尔的?是什么让你真正“打破僵局”的?还有,开始练习有什么好主意吗?


当前回答

这里有一本好书,你可以在线阅读:Real World Haskell

我所做的大多数Haskell程序都是用来解决Project Euler问题的。

不久前我读到的一条建议是,你应该有一套你知道如何解决(理论上)的简单问题的标准集,然后每当你试图学习一种新语言时,你就用这种语言实现这些问题。

其他回答

这里有一本好书,你可以在线阅读:Real World Haskell

我所做的大多数Haskell程序都是用来解决Project Euler问题的。

不久前我读到的一条建议是,你应该有一套你知道如何解决(理论上)的简单问题的标准集,然后每当你试图学习一种新语言时,你就用这种语言实现这些问题。

如果您只有命令式/OO语言的经验,我建议使用更传统的函数式语言作为垫脚石。Haskell是非常不同的,你必须理解很多不同的概念。我建议先使用ml风格的语言(比如f#)。

为了补充别人的答案——有一个有用的答案会在编码时帮助你(例如在解决项目欧拉问题时): Hoogle。可以使用命令行界面,也可以使用web界面。

命令行

在你安装了Haskell平台之后,一定要在cabal上安装hoogle

Hoogle用法示例:

你有一个函数f x = 3 * x + 1,你想把它应用到(5::Int)上,然后把它应用到结果上,然后应用到那个结果上,以此类推,得到一个无限的这些值的列表。你怀疑可能已经存在一个函数来帮助你(虽然不是专门针对你的f)。

该函数的类型为(a -> a) -> a -> [a],如果它的参数为f5;如果它的参数为5f,则为-> (a -> a) -> [a](我们假设该函数适用于一般类型,而不仅仅是int型)

$ hoogle "a -> (a -> a) -> [a]"
Prelude iterate :: (a -> a) -> a -> [a]

是的,你需要的函数已经存在了,它叫做iterate。你可以通过迭代func 5来使用它!

Web界面

可以在这里找到相同示例的结果。

这些是我最喜欢的

Haskell:类型函数式编程

Joeri van Eekelen, et al. | Wikibooks
       Published in 2012, 597 pages

真实世界Haskell

   B. O'Sullivan, J. Goerzen, D. Stewart | OReilly Media, Inc.
   Published in 2008, 710 pages

Graham Hutton的《Programming in Haskell》简明扼要,相当透彻,而且他多年的Haskell教学经验也很好地说明了这一点。这几乎总是我建议人们开始的时候,不管你从哪里开始。

特别是,第8章(“函数解析器”)提供了你需要开始处理单子的真正基础知识,我认为这是目前为止最好的开始,其次是关于单子的所有内容。(不过,关于那一章,请注意网站上的勘误表:如果没有一些特殊帮助,你不能使用do表单。你可能想先了解一下类型类,然后自己解决这个问题。)

Haskell初学者很少会强调这一点,但它值得尽早学习,不仅是使用单子,而且是构造自己的单子。这并不难,定制的可以使许多任务变得更加简单。