新書推薦:
《
知识社会史(下卷):从《百科全书》到“在线百科”
》
售價:NT$
454.0
《
我读巴芒:永恒的价值
》
售價:NT$
602.0
《
你漏财了:9种逆向思维算清人生这本账
》
售價:NT$
254.0
《
我们终将老去:认识生命的第二阶段
》
售價:NT$
418.0
《
祛魅:对世界祛魅是一个人变强的开始
》
售價:NT$
286.0
《
家族财富传承
》
售價:NT$
704.0
《
谁是窃书之人 日本文坛新锐作家深绿野分著 无限流×悬疑×幻想小说
》
售價:NT$
254.0
《
一个经济杀手的自白 第3版
》
售價:NT$
505.0
編輯推薦:
1.ACCU主席Francis Glassborow倾力推荐,影响了国内外好几代程序员的经典作品;
2.C业界资深技术大神、C标准委员会成员、C沉思录作者Andrew Koenig的成名著作;
3.全球畅销30余年,中文版累销100000 册;
4.本书的出发点不是要批判C语言,而是要帮助C程序员绕过编程过程中的陷阱和障碍。
聆听大师教诲 掌握编程精髓
1.ACCU主席Francis Glassborow倾力推荐,影响了国内外好几代程序员的经典作品;
2.C业界资深技术大神、C标准委员会成员、C沉思录作者Andrew Koenig的成名著作;
3.全球畅销30余年,中文版累销100000 册;
4.本书的出发点不是要批判C语言,而是要帮助C程序员绕过编程过程中的陷阱和障碍。
聆听大师教诲 掌握编程精髓
本书对会让程序预期行为与实际行为产生很大不同的C语言特性进行了详细介绍。本书通过具体的案例和有帮助的建议来演示并介绍C语言中的这些陷阱与缺陷。本书每章末尾还包含了一些思考和相应的讨论。
即使是C编程专家,也会经常遇到一些需要数天调试才能修复的问题。本书中的每个示例都
內容簡介:
《C陷阱与缺陷》作者以自己1985年在贝尔实验室时发表的一篇论文为基础,结合自己的工作经验将这篇论文扩展成对C程序员具有珍贵价值的经典著作。本书的出发点不是批判C语言,而是要帮助C程序员绕过编程过程中的陷阱和障碍。
《C陷阱与缺陷》分为8章,分别从词法陷阱、语法陷阱、语义陷阱、链接、库函数、预处理器、可一致性缺陷等几个方面分析了C编程中可能遇到的问题。*后,作者用一章的篇幅给出了若干具有实用价值的建议。
《C陷阱与缺陷》适合有一定经验的C程序员阅读学习,即便你是C编程高手,本书也应该成为你的案头必备图书。
關於作者:
Andrew Koenig,AT&T大规模程序研发部(前贝尔实验室)成员。他从1986年开始从事C语言的研究,1977年加入贝尔实验室。他编写了一些早期的类库,并在1988年组织召开了第一个具有相当规模的C会议。在ISOANSI C委员会成立的1989年,他就加入了该委员会,并一直担任项目编辑。他已经发表了100多篇C方面的论文,并在Addsion-Wesley出版了C Traps and Pitfalls 一书(中文版名为《C缺陷与陷阱》,由人民邮电出版社出版),还应邀到世界各地演讲。 Anderw Koenig不仅有着多年的C开发、研究和教学经验,而且还亲身参与了C的演化和变革,对C的变化和发展产生了重要的影响。
目錄 :
第0章 导读 1
第 1章 词法陷阱 5
1.1 =不同于== 6
1.2 & 和 | 不同于&& 和 || 8
1.3 词法分析中的贪心法 8
1.4 整型常量 10
1.5 字符与字符串 11
第 2章 语法陷阱 15
2.1 理解函数声明 15
2.2 运算符的优先级问题 19
2.3 注意作为语句结束标志的分号 24
2.4 switch语句 26
2.5 函数调用 28
2.6 悬挂else引发的问题 28
第3章 语义陷阱 33
3.1 指针与数组 33
3.2 非数组的指针 39
3.3 作为参数的数组声明 41
3.4 避免举隅法 43
3.5 空指针并非空字符串 44
3.6 边界计算与不对称边界 45
3.7 求值顺序 57
3.8 运算符&&、|| 和 ! 59
3.9 整数溢出 61
3.10 为函数main提供返回值 62
第4章 链接 65
4.1 什么是链接器 65
4.2 声明与定义 67
4.3 命名冲突与static修饰符 69
4.4 形参、实参与返回值 70
4.5 检查外部类型 77
4.6 头文件 80
第5章 库函数 83
5.1 返回整数的getchar函数 84
5.2 更新顺序文件 85
5.3 缓冲输出与内存分配 86
5.4 使用errno检测错误 88
5.5 库函数signal 89
第6章 预处理器 93
6.1 不能忽视宏定义中的空格 94
6.2 宏并不是函数 94
6.3 宏并不是语句 99
6.4 宏并不是类型定义 101
第7章 可移植性缺陷 103
7.1 应对C语言标准变更 104
7.2 标识符名称的限制 106
7.3 整数的大小 107
7.4 字符是有符号整数还是无符号整数 108
7.5 移位运算符 109
7.6 内存位置0 110
7.7 除法运算时发生的截断 111
7.8 随机数的大小 113
7.9 大小写转换 113
7.10 首先释放,然后重新分配 115
7.11 可移植性问题的一个例子 116
第8章 建议与答案 123
8.1 建议 124
8.2 答案 128
附录A printf、varargs与stdarg 147
附录B Koenig和Moo夫妇访谈 169