作者简介:
前桥和弥(Maebasi Kazuya)
1969年出生,著有《征服C指针》、《彻底掌握C语言》、《Java之谜和陷阱》等。其一针见血的“毒舌”文风和对编程语言深刻的见地受到广大读者的欢迎。
作者主页:http://kmaebashi.com/。
译者简介:
刘卓
2004年开始从事对日软件开发工作,其间还从事技术及软件工程相关培训工作。自2011年开始从事电力行业产品研发。持续关注企业级应用架构和Web客户端技术。
徐谦
6年技术开发及项目经验,曾以技术工程师身份赴日本工作两年,后归国联合创办互联网公司,现居上海继续创业中。主要从事PHP方向的Web开发。热爱开源,曾向Zend Framework等知名PHP开源项目贡献代码,并于Github自主研发运维EvaThumber等开源项目获得国内社区认可。乐于分享技术心得,个人技术博客avnpc.com在国内PHP圈小有影响。
吴雅明
13年编程经验。其中7年专注于研发基于Java EE和.NET的开发框架以及基于UML 2.0模型的代码生成工具。目前正带领团队开发云计算PaaS平台及云计算自动化配置部署的系统。译著有《征服C指针》等。
目 录
第1章 引子001
1.1 为什么要制作编程语言002
1.2 自制编程语言并不是很难003
1.3 本书的构成与面向读者004
1.4 用什么语言来制作006
1.5 要制作怎样的语言007
1.5.1 要设计怎样的语法007
1.5.2 要设计怎样的运行方式009
补充知识 “用户”指的是谁?012
补充知识 解释器并不会进行翻译012
1.6 环境搭建012
1.6.1 搭建开发环境012
补充知识 关于bison与flex的安装014
1.6.2 本书涉及的源代码以及编译器015
第2章 试做一个计算器017
2.1 yacc/lex是什么018
补充知识 词法分析器与解析器是各自独立的019
2.2 试做一个计算器020
2.2.1 lex021
2.2.2 简单正则表达式讲座024
2.2.3 yacc026
2.2.4 生成执行文件033
2.2.5 理解冲突所代表的含义034
2.2.6 错误处理040
2.3 不借助工具编写计算器041
2.3.1 自制词法分析器041
补充知识 保留字(关键字)046
补充知识 避免重复包含047
2.3.2 自制语法分析器048
补充知识 预读记号的处理053
2.4 少许理论知识——LL(1)与LALR(1)054
补充知识 Pascal/C 中的语法处理诀窍056
2.5 习题:扩展计算器056
2.5.1 让计算器支持括号056
2.5.2 让计算器支持负数058
第3章 制作无类型语言crowbar061
3.1 制作crowbar ver.0.1语言的基础部分062
3.1.1 crowbar是什么062
3.1.2 程序的结构063
3.1.3 数据类型064
3.1.4 变量064
补充知识 初次赋值兼做变量声明的理由066
补充说明 各种语言的全局变量处理067
3.1.5 语句与结构控制067
补充知识 elif、elsif、elseif的选择068
3.1.6 语句与运算符069
3.1.7 内置函数069
3.1.8 让crowbar支持C 语言调用070
3.1.9 从crowbar中调用C 语言(内置函数的编写)071
3.2 预先准备071
3.2.1 模块与命名规则072
3.2.2 内存管理模块MEM073
补充知识 valgrind075
补充知识 富翁式编程075
补充知识 符号表与扣留操作076
3.2.3 调试模块DBG076
3.3 crowbar ver.0.1的实现077
3.3.1 crowbar的解释器——CRB_Interpreter077
补充知识 不完全类型080
3.3.2 词法分析——crowbar.l081
补充知识 静态变量的许可范围084
3.3.3 分析树的构建——crowbar.y 与create.c085
3.3.4 常量折叠089
3.3.5 错误信息089
补充知识 关于crowbar中使用的枚举型定义091
3.3.6 运行——execute.c092
3.3.7 表达式评估——eval.c096
3.3.8 值——CRB_Value104
3.3.9 原生指针型105
3.3.10 变量106
3.3.11 字符串与垃圾回收机制——string_pool.c108
3.3.12 编译与运行110
第4章 数组和mark-sweep垃圾回收器113
4.1 crowbar ver.0.2114
4.1.1 crowbar的数组114
4.1.2 访问数组元素115
4.1.3 数组是一种引用类型116
补充知识 “数组的数组”和多维数组116
4.1.4 为数组添加元素118
4.1.5 增加( 模拟) 函数调用功能118
4.1.6 其他细节118
4.2 制作mark-sweep GC119
4.2.1 引用数据类型的结构119
4.2.2 mark-sweep GC121
补充知识 引用和immutable123
4.2.3 crowbar栈124
4.2.4 其他根127
4.2.5 原生函数的形式参数128
4.3 实现GC 本身129
4.3.1 对象的管理方法129
4.3.2 GC 何时启动129
4.3.3 sweep阶段132
补充知识 GC 现存的问题133
补充知识 Coping GC134
4.4 其他修改136
4.4.1 修改语法136
4.4.2 函数的模拟137
4.4.3 左值的处理139
4.4.4 创建数组和原生函数的书写方法142
4.4.5 原生指针类型的修改144
第5章 中文支持和Unicode147
5.1 中文支持策略和基础知识148
5.1.1 现存问题148
5.1.2 宽字符(双字节)串和多字节字符串149
补充知识 wchar_t 肯定能表示1 个字符吗?150
5.1.3 多字节字符/ 宽字符之间的转换函数群150
5.2 Unicode153
5.2.1 Unicode的历史153
5.2.2 Unicode的编码方式154
补充知识 Unicode可以固定(字节)长度吗?156
5.3 crowbar book_ver.0.3的实现156
5.3.1 要实现到什么程度?156
5.3.2 发起转换的时机157
5.3.3 关于区域设置158
5.3.4 解决0x5C问题158
补充知识 失败的 #ifdef160
5.3.5 应该是什么样子160
补充知识 还可以是别的样子——Code Set Independent161
第6章 制作静态类型的语言Diksam163
6.1 制作Diksam Ver 0.1语言的基本部分164
6.1.1 Diksam的运行状态164
6.1.2 什么是Diksam165
6.1.3 程序结构165
6.1.4 数据类型166
6.1.5 变量166
6.1.6 语句和流程控制167
6.1.7 表达式167
6.1.8 内建函数168
6.1.9 其他168
6.2 什么是静态的/ 执行字节码的语言169
6.2.1 静态类型的语言169
6.2.2 什么是字节码169
6.2.3 将表达式转换为字节码170
6.2.4 将控制结构转换为字节码173
6.2.5 函数的实现173
6.3 Diksam ver.0.1的实现——编译篇175
6.3.1 目录结构175
6.3.2 编译的概要176
6.3.3 构建分析树(create.c)176
6.3.4 修正分析树(fix_tree.c)179
6.3.5 Diksam的运行形式——DVM_Executable185
6.3.6 常量池186
补充知识 YARV 的情况187
6.3.7 全局变量188
6.3.8 函数189
6.3.9 顶层结构的字节码189
6.3.10 行号对应表190
6.3.11 栈的需要量190
6.3.12 生成字节码(generate.c)191
6.3.13 生成实际的编码193
6.4 Diksam虚拟机197
6.4.1 加载/ 链接DVM_Executable到DVM200
6.4.2 执行——巨大的switch case202
6.4.3 函数调用204
第7章 为Diksam引入数组207
7.1 Diksam中数组的设计208
7.1.1 声明数组类型的变量208
7.1.2 数组常量209
补充知识 D 语言的数组210
7.2 修改编译器210
7.2.1 数组的语法规则210
7.2.2 TypeSpecifier结构体212
7.3 修改DVM213
7.3.1 增加指令213
补充知识 创建Java 的数组常量215
补充知识 C 语言中数组的初始化217
7.3.2 对象217
补充知识 ArrayStoreException218
7.3.3 增加null219
7.3.4 哎! 还缺点什么吧?219
第8章 将类引入Diksam221
8.1 分割源文件222
8.1.1 包和分割源代码222
补充知识 #include、文件名、行号225
8.1.2 DVM_ExecutableList225
8.1.3 ExecutableEntry226
8.1.4 分开编译源代码227
8.1.5 加载和再链接230
补充知识 动态加载时的编译器233
8.2 设计Diksam中的类233
8.2.1 超简单的面向对象入门233
8.2.2 类的定义和实例创建237
8.2.3 继承239
8.2.4 关于接口241
8.2.5 编译与接口242
8.2.6 Diksam怎么会设计成这样?243
8.2.7 数组和字符串的方法245
8.2.8 检查类的类型246
8.2.9 向下转型246
8.3 关于类的实现——继承和多态247
8.3.1 字段的内存布局247
8.3.2 多态——以单继承为前提249
8.3.3 多继承——C++250
8.3.4 Diksam的多继承252
补充知识 无类型语言中的继承254
8.3.5 重写的条件254
8.4 关于类的实现256
8.4.1 语法规则256
8.4.2 编译时的数据结构258
8.4.3 DVM_Executable中的数据结构260
8.4.4 与类有关的指令262
补充知识 方法调用、括号和方法指针263
8.4.5 方法调用264
8.4.6 super266
8.4.7 类的链接266
8.4.8 实现数组和字符串的方法267
8.4.9 类型检查和向下转型267
补充知识 对象终结器(finalizer)和析构函数(destructor)268
第9章 应用篇271
9.1 为crowbar引入对象和闭包272
9.1.1 crowbar的对象272
9.1.2 对象实现273
9.1.3 闭包274
9.1.4 方法276
9.1.5 闭包的实现278
9.1.6 试着跟踪程序实际执行时的轨迹281
9.1.7 闭包的语法规则284
9.1.8 普通函数284
9.1.9 模拟方法(修改版)285
9.1.10 基于原型的面向对象286
9.2 异常处理机制286
9.2.1 为crowbar引入异常286
9.2.2 setjmp()/longjmp()289
补充知识 Java 和C# 异常处理的不同293
9.2.3 为Diksam引入异常295
补充知识 catch 的编写方法296
9.2.4 异常的数据结构297
9.2.5 异常处理时生成的字节码299
9.2.6 受查异常301
补充知识 受查异常的是与非 303
补充知识 异常处理本身的是与非304
9.3 构建脚本305
9.3.1 基本思路306
9.3.2 YY_INPUT307
9.3.3 Diksam的构建脚本308
9.3.4 三次加载/ 链接308
9.4 为crowbar引入鬼车309
9.4.1 关于“鬼车”309
9.4.2 正则表达式常量310
9.4.3 正则表达式的相关函数311
9.5 其他312
9.5.1 foreach 和迭代器(crowbar)312
9.5.2 switch case(Diksam)314
9.5.3 enum(Diksam)315
9.5.4 delegate(Diksam)316
9.5.5 final、const(Diksam)319
附录A crowbar语言的设计322
附录B Diksam语言的设计336
附录C Diksam Virtual Machine 指令集359
编程语言实用化指南——写在最后369
参考文献375
《中国经学史十讲》内容简介:“经”原先只是指代一种纺织工艺,在漫漫历史长河中,其逐渐变成了唯指孔子亲授的儒家五经的专称。朱
《认同、文化与地方历史》内容简介:本书共收录14篇文章,涵盖认同政治、文化与地方历史等方面,既有一般性的人类学理论探讨,也有
Thisbrain-friendlyguideteachesyoueverythingfromJavaScriptlanguagefundamentalstoa...
如果你希望成为一名职业室内设计师,本书将成为你最能受益的实用手册。其中包含的大量参考信息将带给你对这份职业的无限热情和激
《长三角区域一体化发展战略研究》内容简介:本书通过对比分析两大经济区制造业,特别是战略性新兴和高技术产业的发展情况,以及制
网络管理员教程-全国计算机技术与软件专业技术资格(水平)考试指定用书-(第4版) 本书特色本书按照全国计算机技术与软件专业技术资格(水平)考试要求编写,内容紧扣...
矿山水害空间数据挖掘与知识发现的支持向量机理论与方法 内容简介 本书分为理论与应用两大部分, 在理论部分对支持向量机的训练参数、核函数及核参数的选择进行了探讨,...
Rhinoceros Grasshopper 参数化建模(曾旭东) 本书特色 参数化建模技术在辅助建筑设计上的应用越来越广泛,其发展时间短暂,发展速度却令人叹为...
《单读16:新北京人》内容简介:“必须要有一个开始写作的起点。一个地方。”——舍伍德·安德森 “你需要想象北京,北京会满足你的
本书出自美国一位资深的程序设计师GeoffreyJames之手。他以一种幽默、辛辣的眼光审视着发生在程序设计室里的各种故事,并运用东方
《最新日本设计模板:版面设计》着重对海报、DH、POP、书籍等印刷品的设计和运用进行解说,因为“版面设计”存在于人们生活的方方
数位达尔文主义 本书特色 在这本书中,作者对高度竞争的网络经济进行了前所未有的深入考察,概括出立足网络的企业在形形色色的网上市场中生存与发展的7个关键战略。通过...
《明德学校史话》内容简介:本书依据宏富的史料,记述了明德学校艰苦卓绝的办学历程及其辉煌的办学业绩,展示了胡元倓等一批明德人
《销售七步成单法》内容简介:本书专为通信营业厅的销售人员量身打造,提出了七步销售法。把握移动终端产品的全面评估方法,帮助销
《写给Web开发人员看的HTML5教程》通过结合大量实际案例和源代码对HTML5的重要特性进行了详细讲解,内容全面丰富,易于理解。全书
《写给大家看的PPT设计书》,本书作者围绕PPT等电子演示文稿的创建与制作,向大家传授了大量的方法原则及经验心得。其中涵盖PPT准
JabberisasetofprotocolsexpressedinXML,andanextensibleframeworkthatallowspeoplean...
《方汉奇文集(增订版)》内容简介:《方汉奇文集》(增订版)收录了方先生半个多世纪的研究成果和心得,史料丰富、考据严谨、笔法
《LTC与铁三角:从线索到回款》内容简介:营销业务规划的总体逻辑是什么? 如何在组织中授权一线听得见炮声的员工? 如何围绕服务客
絕對好看的「視覺最佳化」工具書,「用看的」行銷新概念、好點子!Amazon網路書店[簡報與技能類書]長銷榜首!揭開傑出人們用簡報