新書推薦:
《
日耳曼通识译丛:复原力:心理抗逆力
》
售價:HK$
34.3
《
海外中国研究·未竟之业:近代中国的言行表率
》
售價:HK$
135.7
《
我们为何建造(城市与生态文明丛书)
》
售價:HK$
89.7
《
算法经济 : 商业逻辑与人类生活的智能演进(生动呈现AI与算法的创新应用与商业价值)
》
售價:HK$
79.4
《
家书中的百年史
》
售價:HK$
79.4
《
偏爱月亮
》
售價:HK$
45.8
《
生物安全与环境
》
售價:HK$
56.4
《
泥土:文明的侵蚀(城市与生态文明丛书)
》
售價:HK$
84.0
編輯推薦:
本书涵盖150多个具体实例,展示了有经验的Clojure开发者如何用这门JVM语言完成各种编程任务。解决方案全面广泛:从构建动态网站和应用数据库到网络通信、云计算、高级测试策略等,面面俱到。这些实例源于全球60多名Clojure开发者。
本书的每个实例不仅可以即学即用,而且其中提供的关于解决方案原理的讨论,让读者可以在模式、方法和技巧上举一反三,从而在遇到本书未提及的其他编程任务时也能游刃有余。
通过阅读本书,你可以:
掌握内建原生数据和复合数据结构;
使用Leiningen工具创建、开发和发布库;
与本地计算机交互;
管理网络通信协议和库;
掌握连接和使用各种数据库的技术;
应用Ring HTTP服务器库构建并维护动态网站;
解决封装、发布、配置、日志等应用任务;
进行云计算和重量级分布式数据处理;
深入研究单元测试、集成测试、模拟测试和基于属性的测试。
內容簡介:
本书以具体实例的形式讲解了Clojure语言在不同领域的应用,不仅介绍如何运用Clojure,而且还展示了很多常见库。书中给出了添加了注释的示例代码,详细分析并解释了数百个真实世界的编程任务。读者既可通过本书深入了解Clojure的精髓,也可将本书用作参考指南,解决具体问题。
關於作者:
Luke VanderHart是一名Clojure和ClojureScript开发者,目前就职于Cognitect公司(Clojure之父在该公司任CTO)。他是Practical Clojure(Apress)和ClojureScript: Up and Running(O''Reilly)的合著者之一,目前在北卡罗来纳州达勒姆市生活和工作。
Ryan Neufeld通晓多种计算机语言,是一名全能型软件开发者,热衷于分布式系统和网络应用开发。Ryan十分善于为客户解决各种或棘手或简单的软件技术问题,及时为客户交付成果。他目前居住于北卡罗来纳州达勒姆市,是Cognitect公司的一名开发人员。
目錄 :
译者序
前言
第1 章 原生数据
1.0 简介
1.1 改变字符串的大小写
1.2 清除字符串中的空白字符
1.3 利用部件构建字符串
1.4 将字符串作为字符序列
1.5 字符与整数的转换
1.6 格式化字符串
1.7 按模式查找字符串
1.8 利用正则表达式从字符串中取出值
1.9 对字符串执行查找和替换
1.10 将字符串切分成部分
1.11 基于数量为字符串加复数
1.12 在字符串、符号和关键字之间的转换
1.13 利用非常大或非常小的数来保持精度
1.14 使用有理数
1.15 解析数字
1.16 数的截断和舍入
1.17 模糊比较
1.18 三角计算
1.19 根据不同的进制输入和输出整数
1.20 计算数值集合的统计值
1.21 位操作
1.22 生成随机数
1.23 操作货币
1.24 生成唯一ID
1.25 得到当前的日期和时间
1.26 用字面值来表示日期
1.27 利用clj-time 解析日期和时间
1.28 利用clj-time 格式化日期
1.29 比较日期
1.30 计算时间间隔的长度
1.31 生成一系列的日期和时间
1.32 利用原生Java 类型生成一系列日期和时间
1.33 根据日期间的关系取得日期
1.34 处理时区
1.35 将Unix 时间戳转换成Date 对象
1.36 将Date 对象转换成Unix 时间戳
第2 章 复合数据
2.0 简介
2.1 创建列表
2.2 从已有的数据结构创建列表
2.3 在列表中“添加”一个元素
2.4 从列表中“移除”一个元素
2.5 测试是否列表
2.6 创建向量
2.7 在向量中“添加”一个元素
2.8 从向量中“移除”一个元素
2.9 取得索引处的值
2.10 设置索引处的值
2.11 创建集
2.12 在集中添加和移除元素
2.13 测试集成员
2.14 使用集操作
2.15 创建映射表
2.16 从映射表中取得值
2.17 从映射表中同时取出多个键
2.18 设置映射表中的键
2.19 用复合值作为映射表的键
2.20 将映射表作为序列(或反过来)
2.21 对映射表应用函数
2.22 一个键保存多个值
2.23 合并映射表
2.24 值的比较与排序
2.25 从集合中移除重复元素
2.26 检测集合是否包含几个值中的一个
2.27 实现定制的数据结构:红黑树(第一部分)
2.28 实现定制的数据结构:红黑树(第二部分)
第3 章 广义计算
3.0 简介
3.1 运行最小的Clojure REPL
3.2 交互式文档
3.3 探索命名空间
3.4 尝试库而不指明依赖关系
3.5 运行Clojure 程序
3.6 从命令行运行程序
3.7 解析命令行参数
3.8 创建定制的项目模板
3.9 构建具有多态行为的函数
3.10 扩展内建的类型
3.11 用core.async 解除消费者和生产者的耦合
3.12 用core.match 为Clojure 表达式制作解析器
3.13 用core.logic 查询层级图
3.14 演奏儿歌
第4 章 本地IO
4.0 简介
4.1 写入STDOUT 和STDERR
4.2 从控制台读入一次击键
4.3 执行系统命令
4.4 访问资源文件
4.5 复制文件
4.6 删除文件或目录
4.7 列出目录中的文件
4.8 文件的内存映射
4.9 读写文本文件
4.10 使用临时文件
4.11 在任意位置读写文件
4.12 并行文件处理
4.13 带归约的并行文件处理
4.14 读写Clojure 数据
4.15 在配置文件中使用edn
4.16 将记录作为edn 值发布
4.17 读取Clojure 数据时处理未知的带标签字面值
4.18 从文件中读取属性
4.19 读写二进制文件
4.20 读写CSV 数据
4.21 读写压缩文件
4.22 处理XML 数据
4.23 读写JSON 数据
4.24 生成PDF 文件
4.25 生成带可滚动文本的GUI 窗口
第5 章 网络IO 和Web 服务
5.0 简介
5.1 发出HTTP 请求
5.2 执行异步HTTP 请求
5.3 发出Ping 请求
5.4 取得并解析RSS 数据
5.5 发送邮件
5.6 用RabbitMQ 实现队列通信
5.7 通过MQTT 与嵌入式设备通信
5.8 并发使用ZeroMQ
5.9 创建TCP 客户端
5.10 创建TCP 服务器
5.11 收发UDP 包
第6 章 数据库
6.0 简介
6.1 连接SQL 数据库
6.2 利用连接池连接SQL 数据库
6.3 操作SQL 数据库
6.4 用Korma 简化SQL
6.5 用Lucene 进行全文查找
6.6 用ElasticSearch 建立数据索引
6.7 使用Cassandra
6.8 使用MongoDB
6.9 使用Redis
6.10 连接Datomic 数据库
6.11 为Datomic 数据库定义数据模式
6.12 向Datomic 写入数据
6.13 从Datomic 数据库中删除数据
6.14 尝试Datomic 事务而不提交
6.15 遍历Datomic 索引
第7 章 Web 应用
7.0 简介
7.1 Ring 简介
7.2 使用Ring 中间件
7.3 用Ring 提供静态文件
7.4 用Ring 处理表单数据
7.5 用Ring 处理Cookie
7.6 用Ring 保存会话
7.7 在Ring 中读写请求和响应的头
7.8 用Compojure 路由请求
7.9 用Ring 执行HTTP 重定向
7.10 用Liberator 构建REST 风格的应用
7.11 用Enlive 实现HTML 模板
7.12 用Selmer 实现模板
7.13 用Hiccup 实现模板
7.14 渲染Markdown 文档
7.15 用Luminus 来构建应用
第8 章 性能与开发效率
8.0 简介
8.1 AOT 编译
8.2 将项目打包成JAR 文件
8.3 创建WAR 文件
8.4 将应用作为守护进程运行
8.5 利用类型暗示减轻性能问题
8.6 用原生Java 数组进行快速数学运算
8.7 用Timbre 进行简单剖析
8.8 用Timbre 记日志
8.9 向Clojars 发布库
8.10 使用宏来简化API 弃用
第9 章 分布式计算
9.0 简介
9.1 用Storm 构建活动推送系统
9.2 用抽取转换加载(ETL)管道来处理数据
9.3 聚合大型文件
9.4 测试Cascalog 工作流
9.5 设置Cascalog 任务的检查点
9.6 解释Cascalog 查询
9.7 在Elastic MapReduce 上运行Cascalog任