《代码的未来》是Ruby之父松本行弘的又一力作。作者对云计算、大数据时代下的各种编程语言以及相关技术进行了剖析,并对编程语言的未来发展趋势做出预测,内容涉及Go、VoltDB、node.js、CoffeeScript、Dart、MongoDB、摩尔定律、编程语言、多核、NoSQL等当今备受关注的话题。
《代码的未来》面向各层次程序设计人员和编程爱好者,也可供相关技术人员参考。
第一章 编程的时间和空间
1.1 编程的本质3
编程的本质是思考4
创造世界的乐趣4
快速提高的性能改变了社会5
以不变应万变8
摩尔定律的局限9
社会变化与编程10
1.2 未来预测13
科学的未来预测14
IT 未来预测14
极限未来预测16
从价格看未来16
从性能看未来17
从容量看未来18
从带宽看未来19
小结20
第二章 编程语言的过去、现在和未来
2.1 编程语言的世界23
被历史埋没的先驱25
编程语言的历史26
编程语言的进化方向30
未来的编程语言32
20 年后的编程语言34
学生们的想象34
2.2 DSL(特定领域语言)36
外部DSL37
内部DSL38
DSL 的优势39
DSL 的定义39
适合内部DSL 的语言40
外部DSL 实例42
DSL 设计的构成要素43
Sinatra46
小结47
2.3 元编程48
Meta, Reflection48
类对象51
类的操作52
Lisp53
数据和程序54
Lisp 程序56
宏56
宏的功与过57
元编程的可能性与危险性59
小结60
2.4 内存管理61
看似无限的内存61
GC 的三种基本方式62
术语定义62
标记清除方式63
复制收集方式64
引用计数方式65
引用计数方式的缺点65
进一步改良的应用方式66
分代回收66
对来自老生代的引用进行记录67
增量回收68
并行回收69
GC 大统一理论69
2.5 异常处理71
“一定没问题的”71
用特殊返回值表示错误72
容易忽略错误处理72
Ruby 中的异常处理73
产生异常74
更高级的异常处理75
Ruby 中的后处理保证76
其他语言中的异常处理77
Java 的检查型异常77
Icon 的异常和真假值78
Eiffel 的Design by Contract80
异常与错误值80
小结81
2.6 闭包82
函数对象82
高阶函数83
用函数参数提高通用性84
函数指针的局限85
作用域:变量可见范围87
生存周期:变量的存在范围88
闭包与面向对象89
Ruby 的函数对象89
Ruby 与JavaScript 的区别90
Lisp-1 与Lisp-291
第三章 编程语言的新潮流
3.1 语言的设计97
客户端与服务器端97
向服务器端华丽转身98
在服务器端获得成功的四大理由99
客户端的JavaScript100
性能显著提升101
服务器端的Ruby102
Ruby on Rails 带来的飞跃102
服务器端的Go103
静态与动态104
动态运行模式105
何谓类型105
静态类型的优点106
动态类型的优点106
有鸭子样的就是鸭子107
Structural Subtyping108
小结108
3.2 Go109
New(新的)109
Experimental(实验性的)109
Concurrent(并发的)110
Garbage-collected(带垃圾回收的)110
Systems(系统)111
Go 的创造者们111
Hello World112
Go 的控制结构113
类型声明116
无继承式面向对象118
多值与多重赋值120
并发编程122
小结124
3.3 Dart126
为什么要推出Dart ?126
Dart 的设计目标129
代码示例130
Dart 的特征132
基于类的对象系统132
非强制性静态类型133
Dart 的未来134
3.4 CoffeeScript135
最普及的语言135
被误解最多的语言135
显著高速化的语言136
对JavaScript 的不满138
CoffeeScript138
安装方法139
声明和作用域139
分号和代码块141
省略记法142
字符串143
数组和循环143
类145
小结146
3.5 Lua148
示例程序149
数据类型149
函数150
表150
元表151
方法调用的实现153
基于原型编程155
和Ruby 的比较(语言篇)157
嵌入式语言Lua157
和Ruby 的比较(实现篇)158
嵌入式Ruby159
第四章 云计算时代的编程
4.1 可扩展性163
信息的尺度感163
大量数据的查找164
二分法查找165
散列表167
布隆过滤器169
一台计算机的极限170
DHT(分布式散列表)171
Roma172
MapReduce173
小结174
4.2 C10K 问题175
何为C10K 问题175
C10K 问题所引发的“想当然”177
使用epoll 功能180
使用libev 框架181
使用EventMachine183
小结185
4.3 HashFold186
HashFold 库的实现(Level 1)187
运用多核的必要性190
目前的Ruby 实现所存在的问题191
通过进程来实现HashFold(Level 2)191
抖动193
运用进程池的HashFold(Level 3)194
小结197
4.4 进程间通信198
进程与线程198
同一台计算机上的进程间通信199
TCPIP 协议201
用C 语言进行套接字编程202
用Ruby 进行套接字编程204
Ruby 的套接字功能205
用Ruby 实现网络服务器208
小结209
4.5 Rack 与Unicorn210
Rack 中间件211
应用程序服务器的问题212
Unicorn 的架构215
Unicorn 的解决方案215
性能219
策略220
小结221
第五章 支撑大数据的数据存储技术
5.1 键- 值存储225
Hash 类225
DBM 类226
数据库的ACID 特性226
CAP 原理227
CAP 解决方案——BASE228
不能舍弃可用性229
大规模环境下的键- 值存储230
访问键- 值存储230
键- 值存储的节点处理231
存储器232
写入和读取233
节点追加233
故障应对233
终止处理235
其他机制235
性能与应用实例236
小结236
5.2 NoSQL237
RDB 的极限237
NoSQL 数据库的解决方案238
形形色色的NoSQL 数据库239
面向文档数据库240
MongoDB 的安装241
启动数据库服务器243
MongoDB 的数据库结构244
数据的插入和查询244
用JavaScript 进行查询245
高级查询246
数据的更新和删除249
乐观并发控制250
5.3 用Ruby 来操作MongoDB251
使用Ruby 驱动251
对数据库进行操作253
数据的插入253
数据的查询253
高级查询254
find 方法的选项256
原子操作257
ActiveRecord259
OD Mapper260
5.4 SQL 数据库的反击264
“云”的定义264
SQL 数据库的极限264
存储引擎Spider265
SQL 数据库之父的反驳265
SQL 数据库VoltDB268
VoltDB 的架构269
VoltDB 中的编程270
Hello VoltDB!271
性能测试273
小结275
5.5 memcached 和它的伙伴们276
用于高速访问的缓存276
memcached277
示例程序278
对memcached 的不满279
memcached 替代服务器280
另一种键- 值存储Redis282
Redis 的数据类型284
Redis 的命令与示例285
小结289
第六章 多核时代的编程
6.1 摩尔定律293
呈几何级数增长293
摩尔定律的内涵294
摩尔定律的结果295
摩尔定律所带来的可能性296
为了提高性能297
摩尔定律的极限302
超越极限303
不再有免费的午餐304
6.2 UNIX 管道305
管道编程306
多核时代的管道308
xargs——另一种运用核心的方式309
注意瓶颈311
阿姆达尔定律311
多核编译312
ccache313
distcc313
编译性能测试314
小结315
6.3 非阻塞I/O316
何为非阻塞IO316
使用read(2) 的方法317
边沿触发与电平触发319
使用read(2) + select 的方法319
使用read+O_NONBLOCK 标志321
Ruby 的非阻塞IO322
使用aio_read 的方法323
6.4 node.js330
减负330
拖延331
委派332
非阻塞编程333
node.js 框架333
事件驱动编程334
事件循环的利弊335
node.js 编程335
node.js 网络编程337
node.js 回调风格339
node.js 的优越性340
EventMachine 与Rev341
6.5 ZeroMQ342
多CPU 的必要性342
阿姆达尔定律343
多CPU 的运用方法343
进程间通信345
管道345
SysV IPC346
套接字347
UNIX 套接字349
ZeroMQ349
ZeroMQ 的连接模型350
ZeroMQ 的安装352
ZeroMQ 示例程序352
小结354
版权声明356
精通D3.js-交互式数据可视化高级编程 本书特色 本书以当前流行的数据可视化技术d3.js为主要内容,分为三大部分,共计13章。**部分讲述基础知识,第二部分...
《南京理工大学史话》内容简介:南京理工大学是隶属于中华人民共和国工业和信息化部的全国重点大学,由创建于1953年的新中国军工科
当技术使整个社会突变到移动互联时代,实现了社群、人人实时在线等质变,企业应该如何在移动互联时代实现生存、进化?。《社群经
各位,下一個最好的投資機會,不在於股票、債券或房地產,而是原物料,也就是我們日常生活基本所需的大宗物資。聰明的投資人已經
《生活之美》内容简介:《生活之美》中国社会科学院研究员、知名美学专家刘悦笛对中国生活美学的赏析解读。“生活美学”中蕴含着华
很多事物中都存在组成(成分、构成)问题。作者创立的组成论为此提供统一的认识模型、分析工具、计算方法和原理。它通过广义集合
精通UG NX 7.0中文版模具设计-(含1DVD) 本书特色 moldwizard是ug nx7.0中的一个子模块,该模块是针对注塑模具制作独立开发...
蜜蜂病虫害防治 内容简介 本书由中国农业科学陆军蜜蜂研究所冯峰研究员等编著。内容包括:蜜蜂的种类、形态、发育阶段和生物学特性,蜜蜂疾病的发生、诊断和防治,蜜蜂的...
《C语言程序设计》内容简介:本书采用“案例引入—理论讲解—案例学习—编程体验”的方式,全面介绍了利用C语言进行结构化程序设计
《人机交互:以用户为中心的设计和评估(第6版)》内容简介:本书计算机系统、互联网、移动终端,带动了人类生活全面的数字化、信息
计算机软件技术基础(第3版) 内容简介 本书是计算机基础教材,全书较系统、通俗地介绍了计算机软件技术的基础知识和常用的系统软件。内容包括数据结构、操作系统、数据...
《世界前沿技术发展报告2020》内容简介:本书于2020年年初编纂,总结了2019年的技术,并对2020年的发展态势做了预判。书中详细介绍
数字图像水印算法及应用 内容简介 数字技术的发展使得人们在享受数字化带来便利的同时,也深陷安全隐患之中。数字图像,作为多媒体形式的主要内容,其获取、修改、传输越...
《CAE分析大系:ABAQUS工程实例详解》内容简介:本书基于全新的机电工程实际案例,以基本理论、分析思路、标准操作流程(SOP)和结果
《我的最后一本减肥书(畅销增修版)》内容简介:修订版依然定位减肥科普,在前版科学减肥理论的基础上重新整理、完善、增订,用大
《香格里拉的茉莉1:深渊之石》内容简介:苏茉莉,一个有着神秘身世的12岁少女,父母几年前相继在探险行动中失踪。中秋节的假期,放
《孟子重估:从牟宗三到西方汉学》内容简介:1.儒家思想资源的重新估定和现代整合一直是学术界、思想界的热门论题,本书以台港新儒
本书以每十年为一单位,对20世纪字体的设计历史以及平面设计中的种种问题进行了分析。本书讲述了当今字体设计的各种趋势,这些趋
《母婴健康照护棘手问题解答:预防出生缺陷 孕育健康宝宝》内容简介:随着预产期临近,准妈妈们最担心的是能否顺利生下宝宝,有什么
Tmall商家成长部(peixun.tmall.com)诞生于天猫旗下,肩负整个天猫电商成长与发展的重任,担负着中国电子商务转型与升级的使命。