`
dogstar
  • 浏览: 275261 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

real world haskell -读书笔记

阅读更多
Prelude> :type map
map :: (a -> b) -> [a] -> [b]

  • -> 右结合 所以 (a -> b) -> [a] -> [b] == ((a -> b) ->( [a] -> [b]))
  • (a->b) 输入为a类型,返回b类型的函数A;
  • ( [a] -> [b])) 输入为[a]类型,返回[b]类型的函数B;
  • ((a -> b) ->( [a] -> [b])) 输入为函数A,返回为函数B
  • 至此map就是一个输入为函数A,返回为函数B的函数.

实例: map (\(x) -> x*2) [1,2] == (map (\(x) -> x*2)) [1,2] 加上函数的currying上面的就好理解了.

oop容易跌入状态同步的泥潭,fp容易跌入函数传来传去的泥潭


Char -> 'a'
String -> "aaaa" === ['a','a','a','a'] / [Char]

list -> [] 不固定长度,同类型.
Tuple -> ("asdf",1,2,4) 初始化好后不可改变.

函数调用左集合 a b c d = (((a b) c) d)

x = 10
x = 11 can't 不能两次给变量赋值 除了类型推导,怎么越看越像erlang,



:type take
 take::Int -> [a] -> [a]  === take:Int -> ([a]->[a])

currying

take 3 [1,2,4,5] 看似多参数,其实是:((take 3) [1,2,,4,5]) = [1,2,4]





Defining a New Data Type

  haskell 原生的也就是list,tuple (erlang也一样).但是haskell可自己定义data type.erlang只能用装成record的tuple.

haskell玩来玩去骨子里也是tuple,但是他封装的好,有类型,有模有样.比erlang强太多.


-------foldl,foldr--------

foldl (+) 0 (1:2:3:[])
          == foldl (+) (0 + 1)             (2:3:[])
          == foldl (+) ((0 + 1) + 2)       (3:[])
          == foldl (+) (((0 + 1) + 2) + 3) []
          ==           (((0 + 1) + 2) + 3)


foldr (+) 0 (1:2:3:[])
          == 1 +           foldr (+) 0 (2:3:[])
          == 1 + (2 +      foldr (+) 0 (3:[])
          == 1 + (2 + (3 + foldr (+) 0 []))
          == 1 + (2 + (3 + 0))


引用
foldl顾名思义从左边,向右卷起来. step zero x
foldr顾名思义从右边,向左卷起来. step x zero
zero位置和方向一致.


In fact, we can even write foldl using foldr!

----------4.6章节

  :type dropWhile
dropWhile :: (a -> Bool) -> [a] -> [a]

                  haskell的function都是单参数.类型标注是右结合.所以如下:

a -> Bool) -> [a] -> [a] = ((a -> Bool) -> ([a] -> [a]))
意思是:接收一个函数(a -> Bool) ,返回一个函数 [a] -> [a]

xs@(_:xs') = "hello"   --------- xs等于hello,xs'等于ello

like erlang (X=[_|T])="hello"



分享到:
评论
3 楼 dogstar 2010-05-01  
forsecond 写道
汗 盗用俺的头像

s.h.i.t,这个是gtalk里的标准头像好不.囧...
2 楼 forsecond 2010-04-30  
汗 盗用俺的头像
1 楼 coolspeed 2009-06-23  
堆叠起来的[传递函数]透明度低于堆叠的对象。很多现在OOP擅长的领域,FP表达困难,应非偶然。
状态同步,目前是最直接的方式,但本身的不自然显而易见,越用越麻烦也是正常了。透明度增加了,人的可控性才能增加,因此我们高兴,但又同时因为透明度增加,复杂度也增加了,因此我们又沮丧。
现实世界里,作用被传递时,传的到底是什么呢?

相关推荐

    Real World Haskell PDF

    在阅读《Real World Haskell》这本书时,你会学习到如何: - 使用GHC(Glasgow Haskell Compiler)编译器进行开发和调试。 - 理解Haskell的基本语法和类型系统。 - 实践函数式编程思维,编写纯函数和避免副作用。 -...

    Real World Haskell 中文版-102116291

    总之,《Real World Haskell》中文版是一部全面的教程,涵盖了从基础知识到高级特性的 Haskell 编程全貌,适合想要深入学习和应用 Haskell 的开发者阅读。通过这本书,读者可以掌握函数式编程思维,了解 Haskell 在...

    real world haskell english

    《Real World Haskell》是Haskell编程语言的一本实践性教程,专为那些希望在实际项目中应用Haskell的开发者设计。这本书英文版的出现,为全球程序员提供了深入了解和学习这一纯函数式编程语言的机会。 Haskell是一...

    Atom-ide-haskell-hoogle,在光标下显示符号的滚动信息。对原子的贡献.zip

    Atom-ide-haskell-hoogle 是一个专门为 Atom 编辑器设计的插件,它整合了 Haskell 的 Hoogle 工具,以提供强大的代码提示和搜索功能。Atom 是一款由 GitHub 开发的开源文本编辑器,它利用现代 web 技术如 HTML、CSS ...

    haskell-mode emacs

    Haskell 是一种功能强大的、纯函数式的编程语言,以其优雅的语法和强大的类型系统闻名。Emacs 是一款经典的、高度可扩展的文本编辑器,它提供了丰富的插件和模式来支持各种编程语言的开发,包括 Haskell。在 Emacs ...

    real-world-haskell-cn:《 Real World Haskell》中文翻译项目

    《Real World Haskell》是一本广泛认可的Haskell编程语言教程,旨在将这门函数式编程语言引入到实际的软件开发环境中。中文翻译项目"real-world-haskell-cn"为中文学习者提供了一个方便的资源,帮助他们理解并掌握...

    haskell-chart, haskell的2D 图表库.zip

    Haskell是一种纯函数式编程语言,以其优雅的语法和强大的类型系统著称。在数据可视化领域,`haskell-chart`库提供了一种高效且灵活的方式来创建2D图表,这对于数据分析、科学计算以及教学等场景非常有用。这个库是...

    Atom-haskell-ghc-mod,哈斯克尔.zip

    **哈斯克尔编程语言与Atom-Haskell-GHC-Mod** 哈斯克尔(Haskell)是一种纯函数式编程语言,以其优雅的语法、强静态类型系统和编译时优化而受到程序员的喜爱。它鼓励使用不可变数据和惰性求值,这使得哈斯克尔在...

    Real World Haskell

    《Real World Haskell》是一本面向实践者的Haskell编程语言教程,旨在帮助读者将Haskell这一纯函数式编程语言应用于实际的软件开发中。Haskell是一种强类型、静态类型的编程语言,以其优雅的语法和数学基础著称,...

    Haskell-Data-Analysis-Cookbook, Haskell数据分析 cookbook的附带源代码.zip

    Haskell-Data-Analysis-Cookbook, Haskell数据分析 cookbook的附带源代码 Haskell-Data-Analysis-Cookbook这是 Haskell数据分析 cookbook的附带源代码。最新的源代码可以在GitHub上获得: ...

    Atom-haskell-debug,使用ghci在atom中实现图形haskell调试器.zip

    Atom-Haskell-Debug是针对Haskell开发者的一个强大工具,它允许你在流行的Atom文本编辑器中集成一个图形化的Haskell调试器。这个工具基于GHCi(Glasgow Haskell Compiler Interface),GHCi是Haskell的交互式环境,...

    haskell-ghc-mod:haskell-ghc-mod原子包

    从1.0.0开始,haskell-ghc-mod提供haskell-completion-backend服务。 注意:在1.0.0之前,提供了ide-backend服务。 它已被废弃以支持ide-haskell的UPI。 您可以在找到描述 执照 版权所有:copyright:2015 Atom-...

    haskell-ghc-mod:haskell-ghc-mod原子包

    haskell-ghc-mod原子包 该软件包主要用作后端。 Haskell ghc-mod打开通往ghc-modi的管道,并查询类型,信息并检查错误。 安装与配置 请参考官方文档站点 服务中心API 从1.0.0版本开始,haskell-ghc-mod提供...

    Get Programming with HASKELL-2018-英文版.pdf

    Get Programming with HASKELL-2018-英文版

    book-real-world-haskell:真实世界的Haskell源代码

    《真实世界的Haskell》是一本深受Haskell编程爱好者欢迎的开源书籍,它的源代码存放在名为"book-real-world-haskell-master"的压缩包文件中。这本书深入浅出地介绍了Haskell这一纯函数式编程语言,旨在帮助开发者从...

    Atom-atom-haskell-scry,扩散系数.zip

    【标题】:“Atom-atom-haskell-scry,扩散系数.zip” 涉及的主要知识点是 Atom 编辑器与 Haskell 语言的集成以及 SCRY 工具的使用。 【描述】:“Atom-atom-haskell-scry.zip”的描述指出,这个压缩包包含了一个名...

    haskell-relational-record-driver-mysql:用于 haskell-relational-record 的 MySQL 驱动程序

    用于 haskell-relational-record 的 MySQL 驱动程序 这个项目被合并到 。 准备 $ git clone git@github.com:khibino/haskell-relational-record.git $ git clone git@github.com:bos/hdbc-mysql.git $ git clone ...

    real world haskell

    HASKELL编程的进级书,介绍的很详细,但是可能前面的比较跳,可以先看programming in haskell之类的入门书再看这个

Global site tag (gtag.js) - Google Analytics