注重体验与质量的电子书资源下载网站
分类于: 编程语言 计算机基础
简介
C++函数式编程 豆 0.0分
资源最后更新于 2020-10-28 12:16:44
作者:[塞尔维亚]伊凡·库奇
译者:程继洪
出版社:机械工业出版社
出版日期:2020-01
ISBN:9787111641988
文件格式: pdf
标签: C++ 函数式编程 程序设计 软件设计 软件工程 计算机 编程 FP
简介· · · · · ·
本书介绍了C++的面向函数式编程。面向函数式编程是继面向对象编程之后又一编程范式,解决了命令式过程式编程与面向对象编程中出现的问题,是一种极具潜力的编程方式,值得研究和学习。主要讲解了函数对象、Purity、惰性求值、range、函数式数据结构、代数类型以及模式匹配、monad、模版元编程、并发系统的函数式设计,以及测试与调试等有关内容,还介绍了使用原有函数创建新函数的知识。
本书不仅可以作为C++程序员、编程爱好者以及软件工程师学习函数式编程的参考书,还可以作为 高等院校C++编程语言的高级教材。
目录
译者序
致谢
前言
关于本书
关于作者
第1章函数式编程简介
1.1什么是函数式编程?
1.1.1与面向对象编程的关系
1.1.2命令式与声明式编程的比较
1.2纯函数(Pure functions)
1.2.1避免可变状态
1.3以函数方式思考问题·
1.4函数式编程的优点
1.4.1 代码简洁易读
1. .4.2并发和同步
1.4.3持续优化
1.5 C++作为函数式编程语言的进化
1.6将会学到什么
总结
第2章函数式编程之旅
2.1函数使用函数?
2.2STL实例
2.2.1求平均值
2.2.2折叠(Folding)
2.2.3删除字符串空白符
2.2.4基于谓词分割集合
2.2.5过滤(Filtering) 和转换(Transforming)
2.3 STL算法的可组合性
2.4编写自己的高阶函数
2.4.1接收函数作为参数
2.4.2用循环实现
2.4.3递归(Recursion) 和尾调用优化(Tail-call optimization)
2.4.4使用折叠实现
总结
第3章函数对象
3.1函数和函数对象
3.1.1自动推断返回值类型
3.1.2函数指针
3.1.3调用操作符重载
3.1.4创建通用函数对象
3.2 lambda和闭包(Closure)
3.2.1 lambda语法
3.2.2 lambda详解
3.2.3在lambda中创建任意成员变量
3.2.4通用lambda表达式
3.3编写比lambda更简洁的函数对象
3.3.1 STL中的操作符函数对象
3.3.2其他库中的操作符函数对象
3.4用stl::function包装函数对象
总结.
第4章以旧函数创建新函数
4.1偏函数应用
4.1.1把二元函数转换成一元函数的通用方法
4.1.2使用std::bind绑定值到特定的函数参数
4.1.3二元函数参数的反转
4.1.4对多参数函数使用std::bind
4.1.5使用lambda替代stl::bind
4.2柯里化(Currying) :看待函数不同的方式
4.2.1创建柯里化函数的简单方法
4.2.2数据库访问柯里化
4.2.3柯里化与偏函数应用.
4.3函数组合
4.4函数提升(复习)
4.4.1键值对列表反转
.总结
第5章纯洁性:避免可变状态
5.1可变状态带来的问题
5.2纯函数和弓|用透明
5.3无副作用编程
5.4并发环境中的可变状态与不可变状态
5.5 const的重要性
5.5.1逻辑const与内部const
5.5.2对于临时值优化成员函数
5.5.3 const的缺陷
.总结
第6章惰性求值
6.1 C++的惰性
6.2惰性作为一种优化技术
6.2.1集合惰性排序
6.2.2用户接口中的列表视图
6.2.3通过缓存函数结果修剪递归树
6.2.4动态编程作为惰性形式
6.3通用记忆化(Generalized memoization)
6.4表达式模板与惰性字符串拼接
6.4.1纯洁性与表达式模板
总结
第7章range
7.1 range简介
7.2创建数据的只读视图
7.2.1 range的filter 函数
7.2.2 range的transform函数
7.2.3 range惰性求值
7.3修改range中的值
7.4定界rang和无限range
7.4.1用定界range优化用于输入的range
7.4.2用哨兵创建无限range
7.5用range统计词频
.总结
第8章函数式数据结构
8.1不可变链表(Immutable linked lists)
8.1.1在表头添加和删除元素
8.1.2在链表末尾添加和删除元素
8.1.3在链表中间添加和删除元素
8.1.4内存管理
8.2不可变类向量结构
8.2.1位图向量树中的元素查找
8.2.2向位图向量树追加元素
8.2.3位图向量树的修改
8.2.4在位图向量树的末尾删除元素
8.2.5其他操作和位图向量树的整体效率
总结
第9章代数数据类型及模式匹配
9.1代数数据类型
9.1.1通过继承实现和类型
9.1.2通过union和std:variant实现和类型
9.1.3特定状态的实现
9.1.4特殊的和类型: Optional
9.1.5和类型用于错误处理
9.2使用代数数据类型进行域建模
9.2.1原始的方法及其缺点
9.2.2更复杂的方法:自. 上而下的设计
9.3使用模式匹配更好地处理代数数据类型
9.4 Mach7的强大匹配功能
总结
第10章monad
10.1仿函数并不是以前的仿函数
10.1.1处理可选值
10.2 monad:更强大的仿函数
10.3基本的例子
10.4 range与monad的嵌套使用
10.5错误处理
10.5.1 stl::optional<T>作为monad
10.5.2 expected<T, E>作为monad
10.5.3 try monad
10.6 monad状态处理
10.7并发和延续monad
10.7.1 future 作为monad
10.7.2 future的实现
10.8 monad组合
总结
第11章模板元编程
11.1编译时操作类型
11.1.1推断类型调试
11.1.2编译时的模式匹配
11.1.3提供类型的元信息
11.2编译时检查类型的属性
11.3构造科里化函数
11.3.1调用所有可调用的
11.4 DSL构建块
总结
第12章并发系统的函数式设计
12.1 Actor模型:组件思想
12.2创建简单的消息源
12.3将反应流建模为monad
12.3.1创建宿(Sink) 接收消息
12.3.2转换反应流
12.3.3创建给定值的流
12.3.4连接流
12.4过滤反应流
12.5反应流的错误处理
12.6响应客户端
12.7创建状态可修改的Actor
12.8用Actor编写分布式系统
总结
第13章测试与调试
13.1程序编译正确吗?
13.2单元测试与纯函数
13.3自动产生测试
13.3.1产生测试用例
13.3.2基于规则的测试
13.3.3比较测试
13.4测试基于monad的并发系统
总结
致谢
前言
关于本书
关于作者
第1章函数式编程简介
1.1什么是函数式编程?
1.1.1与面向对象编程的关系
1.1.2命令式与声明式编程的比较
1.2纯函数(Pure functions)
1.2.1避免可变状态
1.3以函数方式思考问题·
1.4函数式编程的优点
1.4.1 代码简洁易读
1. .4.2并发和同步
1.4.3持续优化
1.5 C++作为函数式编程语言的进化
1.6将会学到什么
总结
第2章函数式编程之旅
2.1函数使用函数?
2.2STL实例
2.2.1求平均值
2.2.2折叠(Folding)
2.2.3删除字符串空白符
2.2.4基于谓词分割集合
2.2.5过滤(Filtering) 和转换(Transforming)
2.3 STL算法的可组合性
2.4编写自己的高阶函数
2.4.1接收函数作为参数
2.4.2用循环实现
2.4.3递归(Recursion) 和尾调用优化(Tail-call optimization)
2.4.4使用折叠实现
总结
第3章函数对象
3.1函数和函数对象
3.1.1自动推断返回值类型
3.1.2函数指针
3.1.3调用操作符重载
3.1.4创建通用函数对象
3.2 lambda和闭包(Closure)
3.2.1 lambda语法
3.2.2 lambda详解
3.2.3在lambda中创建任意成员变量
3.2.4通用lambda表达式
3.3编写比lambda更简洁的函数对象
3.3.1 STL中的操作符函数对象
3.3.2其他库中的操作符函数对象
3.4用stl::function包装函数对象
总结.
第4章以旧函数创建新函数
4.1偏函数应用
4.1.1把二元函数转换成一元函数的通用方法
4.1.2使用std::bind绑定值到特定的函数参数
4.1.3二元函数参数的反转
4.1.4对多参数函数使用std::bind
4.1.5使用lambda替代stl::bind
4.2柯里化(Currying) :看待函数不同的方式
4.2.1创建柯里化函数的简单方法
4.2.2数据库访问柯里化
4.2.3柯里化与偏函数应用.
4.3函数组合
4.4函数提升(复习)
4.4.1键值对列表反转
.总结
第5章纯洁性:避免可变状态
5.1可变状态带来的问题
5.2纯函数和弓|用透明
5.3无副作用编程
5.4并发环境中的可变状态与不可变状态
5.5 const的重要性
5.5.1逻辑const与内部const
5.5.2对于临时值优化成员函数
5.5.3 const的缺陷
.总结
第6章惰性求值
6.1 C++的惰性
6.2惰性作为一种优化技术
6.2.1集合惰性排序
6.2.2用户接口中的列表视图
6.2.3通过缓存函数结果修剪递归树
6.2.4动态编程作为惰性形式
6.3通用记忆化(Generalized memoization)
6.4表达式模板与惰性字符串拼接
6.4.1纯洁性与表达式模板
总结
第7章range
7.1 range简介
7.2创建数据的只读视图
7.2.1 range的filter 函数
7.2.2 range的transform函数
7.2.3 range惰性求值
7.3修改range中的值
7.4定界rang和无限range
7.4.1用定界range优化用于输入的range
7.4.2用哨兵创建无限range
7.5用range统计词频
.总结
第8章函数式数据结构
8.1不可变链表(Immutable linked lists)
8.1.1在表头添加和删除元素
8.1.2在链表末尾添加和删除元素
8.1.3在链表中间添加和删除元素
8.1.4内存管理
8.2不可变类向量结构
8.2.1位图向量树中的元素查找
8.2.2向位图向量树追加元素
8.2.3位图向量树的修改
8.2.4在位图向量树的末尾删除元素
8.2.5其他操作和位图向量树的整体效率
总结
第9章代数数据类型及模式匹配
9.1代数数据类型
9.1.1通过继承实现和类型
9.1.2通过union和std:variant实现和类型
9.1.3特定状态的实现
9.1.4特殊的和类型: Optional
9.1.5和类型用于错误处理
9.2使用代数数据类型进行域建模
9.2.1原始的方法及其缺点
9.2.2更复杂的方法:自. 上而下的设计
9.3使用模式匹配更好地处理代数数据类型
9.4 Mach7的强大匹配功能
总结
第10章monad
10.1仿函数并不是以前的仿函数
10.1.1处理可选值
10.2 monad:更强大的仿函数
10.3基本的例子
10.4 range与monad的嵌套使用
10.5错误处理
10.5.1 stl::optional<T>作为monad
10.5.2 expected<T, E>作为monad
10.5.3 try monad
10.6 monad状态处理
10.7并发和延续monad
10.7.1 future 作为monad
10.7.2 future的实现
10.8 monad组合
总结
第11章模板元编程
11.1编译时操作类型
11.1.1推断类型调试
11.1.2编译时的模式匹配
11.1.3提供类型的元信息
11.2编译时检查类型的属性
11.3构造科里化函数
11.3.1调用所有可调用的
11.4 DSL构建块
总结
第12章并发系统的函数式设计
12.1 Actor模型:组件思想
12.2创建简单的消息源
12.3将反应流建模为monad
12.3.1创建宿(Sink) 接收消息
12.3.2转换反应流
12.3.3创建给定值的流
12.3.4连接流
12.4过滤反应流
12.5反应流的错误处理
12.6响应客户端
12.7创建状态可修改的Actor
12.8用Actor编写分布式系统
总结
第13章测试与调试
13.1程序编译正确吗?
13.2单元测试与纯函数
13.3自动产生测试
13.3.1产生测试用例
13.3.2基于规则的测试
13.3.3比较测试
13.4测试基于monad的并发系统
总结