×
暂无评论
图文详情
  • ISBN:9787115335593
  • 装帧:一般胶版纸
  • 册数:暂无
  • 重量:暂无
  • 开本:16开
  • 页数:301
  • 出版时间:2014-01-01
  • 条形码:9787115335593 ; 978-7-115-33559-3

本书特色

动手实践书中想象力丰富、略有点儿疯狂的示例,你将能够:挥舞纯函数式编程技法,笑看各种“副作用”。施展Haskell的“惰性”魔法,处理无限数据集。通过自定义类型、类型类和模块来组织程序。使用Haskell优雅的输入/输出系统与外部世界分享程序的灵魂。学习Haskell这门强大的语言,再没有比阅读这本书更好的方法了!

内容简介

《Haskell趣学指南》是一本讲解Haskell这门函数式编程语言的入门指南,语言通俗易懂,插图生动幽默,示例短小清晰,结构安排合理。书中从Haskell的基础知识讲起,涵盖了所有的基本概念和语法,内容涉及基本语法、递归、类型和类型类、函子、applicative 函子、monad、zipper及所有Haskell重要特性和强大功能。 《Haskell趣学指南》适合对函数式编程及Haskell语言感兴趣的开发人员阅读。

目录

第1章 各就各位,预备! 11.1 调用函数 31.2 小朋友的**个函数 41.3 列表入门 61.3.1 拼接列表 61.3.2 访问列表中的元素 81.3.3 嵌套列表 81.3.4 比较列表 81.3.5 更多列表操作 91.4 得州区间 111.5 我是列表推导式 131.6 元组 161.6.1 使用元组 161.6.2 使用序对 171.6.3 找直角三角形 18第2章 相信类型 202.1 显式类型声明 202.2 Haskell的常见类型 212.3 类型变量 222.4 类型类入门 232.4.1 Eq类型类 242.4.2 Ord类型类 242.4.3 Show类型类 252.4.4 Read类型类 252.4.5 Enum类型类 272.4.6 Bounded类型类 272.4.7 Num类型类 282.4.8 Floating类型类 282.4.9 Integeral类型类 282.4.10 有关类型类的*后总结 29第3章 函数的语法 303.1 模式匹配 303.1.1 元组的模式匹配 323.1.2 列表与列表推导式的模式匹配 323.1.3 As模式 343.2 注意,哨卫! 343.3 where?! 363.3.1 where的作用域 373.3.2 where中的模式匹配 383.3.3 where块中的函数 383.4 let 393.4.1 列表推导式中的let 403.4.2 GHCi中的let 403.5 case表达式 41第4章 你好,递归 434.1 不可思议的*大值 434.2 更多的几个递归函数 454.2.1 replicate 454.2.2 take 454.2.3 reverse 464.2.4 repeat 464.2.5 zip 464.2.6 elem 474.3 快点,排序! 474.3.1 算法思路 474.3.2 编写代码 484.4 递归地思考 49第5章 高阶函数 505.1 柯里函数 505.1.1 截断 525.1.2 打印函数 535.2 再来点儿高阶函数 535.2.1 实现zipWith 545.2.2 实现flip 555.3 函数式程序员工具箱 565.3.1 map函数 565.3.2 filter函数 575.3.3 有关map与filter的更多示例 585.3.4 映射带有多个参数的函数 605.4 lambda 605.5 折叠纸鹤 625.5.1 通过foldl进行左折叠 635.5.2 通过foldr进行右折叠 635.5.3 foldl1函数与foldr1函数 645.5.4 折叠的几个例子 655.5.5 另一个角度看折叠 665.5.6 无限列表的折叠 675.5.7 扫描 685.6 有$的函数应用 685.7 函数组合 705.7.1 带有多个参数函数的组合 705.7.2 Point-Free风格 71第6章 模块 736.1 导入模块 736.2 使用模块中的函数求解问题 756.2.1 统计单词数 756.2.2 干草堆中的缝纫针 766.2.3 凯撒密码沙拉 776.2.4 严格左折叠 796.2.5 寻找酷数 806.3 映射键与值 826.3.1 几乎一样好:关联列表 826.3.2 进入Data.Map 836.4 构造自己的模块 876.4.1 几何模块 876.4.2 模块的层次结构 89第7章 构造我们自己的类型和类型类 917.1 定义新的数据类型 917.2 成型 927.2.1 借助Point数据类型优化Shape数据类型 937.2.2 将图形导出到模块中 947.3 记录语法 957.4 类型参数 977.4.1 要不要参数化我们的汽车? 997.4.2 末日向量 1007.5 派生实例 1027.5.1 相同的人 1027.5.2 告诉我怎么读 1037.5.3 法庭内保持秩序! 1047.5.4 一周的一天 1057.6 类型别名 1067.6.1 使我们的电话本更好看些 1077.6.2 参数化类型别名 1087.6.3 向左走,向右走 1097.7 递归数据结构 1117.7.1 优化我们的列表 1117.7.2 种一棵树 1137.8 类型类 1157.8.1 深入Eq类型类 1167.8.2 TrafficLight数据类型 1167.8.3 子类化 1187.8.4 作为类型类实例的带参数类型 1187.9 Yes-No类型类 1207.10 Functor类型类 1227.10.1 Maybe函子 1247.10.2 树也是函子 1247.10.3 Either a函子 1257.11 kind与无名类型 126第8章 输入与输出 1288.1 纯粹与非纯粹的分离 1288.2 Hello, World! 1298.3 组合I/O操作 1308.3.1 在I/O操作中使用let 1328.3.2 反过来 1338.4 几个实用的I/O函数 1358.4.1 putStr 1358.4.2 putChar 1358.4.3 print 1368.4.4 when 1378.4.5 sequence 1378.4.6 mapM 1388.4.7 forever 1398.4.8 forM 1398.5 I/O操作回顾 140第9章 更多的输入输出操作 1419.1 文件和流 1419.1.1 输入重定向 1419.1.2 从输入流获取字符串 1429.1.3 转换输入 1449.2 读写文件 1469.2.1 使用withFile函数 1479.2.2 bracket的时间到了 1489.2.3 抓住句柄 1499.3 TODO列表 1499.3.1 删除条目 1509.3.2 清理 1529.4 命令行参数 1539.5 关于TODO列表的更多有趣的事 1549.5.1 一个多任务列表 1559.5.2 处理错误的输入 1589.6 随机性 1599.6.1 掷硬币 1609.6.2 更多随机函数 1619.6.3 随机性和I/O 1629.7 字节串 1659.7.1 严格的和惰性字节串 1669.7.2 用字节串复制文件 167第10章 函数式地解决问题 16910.1 逆波兰式计算器 16910.1.1 计算RPN表达式 16910.1.2 写一个RPN函数 17010.1.3 添加更多的操作符 17210.2 从希思罗机场到伦敦 17310.2.1 计算*快的路线 17410.2.2 在Haskell中表示道路系统 17610.2.3 实现计算*佳路径的函数 17710.2.4 从输入获取道路系统 179第11章 applicative函子 18211.1 函子再现 18211.1.1 作为函子的I/O操作 18311.1.2 作为函子的函数 18511.2 函子定律 18711.2.1 定律1 18811.2.2 定律2 18811.2.3 违反定律 18911.3 使用applicative函子 19111.3.1 向applicative问好 19211.3.2 Maybe applicative函子 19211.3.3 applicative风格 19311.3.4 列表 19511.3.5 IO也是applicative函子 19711.3.6 函数作为applicative 19811.3.7 zip列表 19911.3.8 applicative定律 20011.4 applicative的实用函数 201第12章 Monoid 20512.1 把现有类型包裹成新类型 20512.1.1 用newtype创建类型类的实例 20712.1.2 关于newtype的惰性 20812.1.3 type、newtype和data三者的对比 21012.2 关于那些monoid 21112.2.1 Monoid类型类 21212.2.2 monoid定律 21312.3 认识一些monoid 21312.3.1 列表是monoid 21312.3.2 Product和Sum 21412.3.3 Any和All 21612.3.4 Ordering monoid 21712.3.5 Maybe monoid 21912.4 monoid的折叠 221第13章 更多monad的例子 22413.1 升级我们的applicative函子 22413.2 体会Maybe 22513.3 Monad类型类 22813.4 一往无前 22913.4.1 代码,代码,代码 23013.4.2 我要飞走 23113.4.3 线上的香蕉 23413.5 do记法 23513.5.1 按我所说的去做 23613.5.2 我皮埃尔又回来了 23713.5.3 模式匹配和计算失败 23813.6 列表monad 23913.6.1 do记法和列表推导式 24113.6.2 MonadPlus和guard函数 24213.6.3 马的探索 24313.7 monad定律 24513.7.1 左单位元 24613.7.2 右单位元 24613.7.3 结合律 247第14章 再多一些monad 24914.1 Writer?我没听说过啊! 24914.1.1 monad赶来营救 25114.1.2 Writer类型 25314.1.3 对Writer使用do记法 25414.1.4 给程序添加日志 25514.1.5 低效的列表构造 25714.1.6 使用差分列表 25814.1.7 比较性能 25914.2 Reader?呃,不开玩笑了 26014.2.1 作为monad的函数 26114.2.2 Reader monad 26114.3 带状态计算的优雅表示 26214.3.1 带状态的计算 26314.3.2 栈和石头 26414.3.3 State monad 26514.3.4 获取和设置状态 26714.3.5 随机性和State monad 26814.4 墙上的Error 26914.5 一些实用的monad式的函数 27114.5.1 liftM和它的朋友们 27114.5.2 join函数 27414.5.3 filterM 27614.5.4 foldM 27814.6 创建一个安全的RPN计算器 27914.7 组合monad式的函数 28114.8 创建monad 282第15章 zipper 28715.1 在树上移动 28715.1.1 面包屑 29015.1.2 向上走 29115.1.3 处理焦点处的树 29315.1.4 一路走到顶端,那里的空气既新鲜又干净 29415.2 在列表上定位 29415.3 一个非常简单的文件系统 29515.3.1 为文件系统创建一个zipper 29615.3.2 操作文件系统 29815.4 小心行事 29915.5 谢谢阅读! 301
展开全部

作者简介

作者介绍Miran Lipova?a 斯洛文尼亚共和国卢布尔雅那城的一位计算机科学专业的学生。除了对Haskell的狂热,他还喜欢拳击,玩低音吉他,当然还有画画。译者介绍李亚舟 毕业于山东理工大学,现就职于IBM LTC,从事Linux发行版相关工作。对内核、体系结构、编程语言及技术翻译有浓厚兴趣,敬仰那些孜孜不倦地精益求精的人们。宋方睿 本科生,清华大学开源镜像站维护者,blue-lotus战队成员,热爱算法和程序设计语言理论,关注高性能计算、自然语言处理及前端技术。个人博客http://maskray.me。

预估到手价 ×

预估到手价是按参与促销活动、以最优惠的购买方案计算出的价格(不含优惠券部分),仅供参考,未必等同于实际到手价。

确定
快速
导航