v

您的位置:VeryCD图书计算机与网络

图书资源事务区


《0 bug:C/C++商用工程之道》扫描版[PDF]

  • 状态: 精华资源
  • 摘要:
    图书分类网络
    出版社电子工业出版社
    发行时间2009年12月3日
    语言简体中文
  • 时间: 2013/05/09 00:43:13 发布 | 2013/05/09 02:20:51 更新
  • 分类: 图书  计算机与网络 

slholmes

精华资源: 762

全部资源: 762

相关: 分享到新浪微博   转播到腾讯微博   分享到开心网   分享到人人   分享到QQ空间   订阅本资源RSS更新   美味书签  subtitle
该内容尚未提供权利证明,无法提供下载。
中文名0 bug:C/C++商用工程之道
作者肖舸
图书分类网络
资源格式PDF
版本扫描版
出版社电子工业出版社
书号9787121098482
发行时间2009年12月3日
地区大陆
语言简体中文
简介

IPB Image

评论处1楼有网盘链接


内容介绍:

  本书主要针对c/c++语言在商用工程开发中的程序实战进行论述,从需求出发,从商用解决方案的角度来理解c和c++语言的程序设计技巧。首先讨论商用开发的原则,然后是基础知识、基本技巧,接着是无错化方法,最后提升到世界观层面论述并行开发的正确理念。商用程序员在实际工作中最为关注的无错化、并行、时间片、内存池、线程池、任务池、工程库和跨平台等相关问题,在本书中都有宝贵的经验总结和理念梳理。本书不是教科书,更多的是在开发技巧、测试调试、工程代码库等方面给出实例与总结。本书也可以说是教科书,作者试图通过实战技巧的训练,帮助读者升华出一种全新的程序设计理念。本书可以帮助你摆脱“training”式编程开发思维与方法,培养“商用”和“产品”标准的工程开发技能。.
   本书适合作为c和c++的程序员进行“商用化开发”和“工程化开发”的参考。...


内容截图:

IPB Image



目录

第1章 商用工程开发思路. 1
1.1 系统分析初步 2
1.1.1 需求理解和沟通 2
1.1.2 “上家”和“下家” 3
1.1.3 角色“定名” 3
1.1.4 初步的拓扑图 4
1.1.5 后续的模块级设计 4
1.1.6 商用设计思维 5
1.2 商用程序员对开发的理解 5
1.2.1 资源和成本 5
1.2.2 盈利导向 6
1.2.3 客观 7
1.2.4 平衡 9
1.2.5 服务 11
1.3 基本开发思路 15
1.3.1 边界 15
1.3.2 “细分”的分析方法 16
1.3.3 灵活,逆向思维 17
1.3.4 小内核,大外延,工程库思维 18
1.3.5 单笔交易失败不算失败 19
.1.4 数据传输各个角色的开发思路 20
1.4.1 服务器的设计原则 20
1.4.2 pc客户端的开发思路 21
1.4.3 嵌入式设备的开发思路 22
1.4.4 跨平台软件模块的开发思路 23
第2章 基础知识 25
2.1 内存的理解 26
2.1.1 32位操作系统的内存分配 26
2.1.2 c/c++语言对内存的使用 27
2.1.3 内存——bug之源 30
2.2 并行运算 31
2.2.1 时间片 31
2.2.2 进程和线程 32
2.2.3 同步和异步 33
2.2.4 礼貌地释放时间片资源 35
2.2.5 跨线程通信 36
2.2.6 跨进程通信 39
2.2.7 网络,并行运算的世界 40
2.3 “锁”的使用 41
2.3.1 为什么要使用锁 41
2.3.2 使用锁容易犯什么错误 42
2.3.3 “行为锁”和“资源锁” 46
2.3.4 单写多读锁 48
2.3.5 不可重入锁 49
2.3.6 用锁的最高境界——不用 50
2.4 “池”的深刻含义 51
2.4.1 “池”的由来 51
2.4.2 “池”的使用 53
2.5 跨平台、跨语言开发基础 54
2.5.1 c/c++跨平台开发基础 54
2.5.2 dll和so 55
2.5.3 api和npi 55
2.5.4 服务无处不在 56
2.6 debug的重要性 57
2.6.1 在数据传输领域,你亲眼看到的都不是真的 57
2.6.2 如何看到——万事从debug开始 60
2.6.3 debug的原则 60
2.6.4 如何分析数据 61
2.7 性能统计的重要性 62
2.7.1 需要统计哪些信息 62
2.7.2 基本的统计方法 63
2.7.3 随机数的产生 65
2.8 队列无处不在 65
2.8.1 数据结构在数据传输中的应用分析 65
2.8.2 需要哪几种队列形式 66
2.9 不要求全责备 66
第3章 c/c++无错化程序设计 69
3.1 “无错化程序设计”简介 71
3.1.1 无错化程序设计思路 71
3.1.2 c/c++无错化设计的解决方案 72
3.1.3 使用后的效果 73
3.2 计算机程序的真谛 74
3.2.1 程序就是“搬数” 74
3.2.2 程序就是“写文章” 75
3.2.3 程序就是“复制” 77
3.2.4 笔者看程序设计 78
3.3 定名 79
3.3.1 匈牙利命名法 79
3.3.2 函数命名原则 80
3.3.3 变量命名原则 81
3.3.4 其他命名规则 83
3.3.5 定名的折中 86
3.4 无错化程序的基本书写原则 87
3.4.1 写简单易懂的程序 88
3.4.2 严禁变量转义 90
3.4.3 严禁一语多义 91
3.4.4 函数只能有一个出口 92
3.4.5 变量如不使用,保持初值 95
3.4.6 常量必须定名 97
3.4.7 太大数组不要用静态方式 98
3.4.8 尽量避免使用递归 99
3.4.9 解决方案一套就够 99
3.5 基本程序设计原则 100
3.5.1 函数的设计 100
3.5.2 类的设计 102
3.5.3 其他要点 116
3.6 基本语句的约定 122
3.6.1 判断语句,常量永远在左边 122
3.6.2 for (i = 0; i ( n; i + +) 124
3.6.3 while(1) 125
3.6.4 不要使用do...while( ) 125
3.6.5 i++和++i问题 126
3.6.6 请不要使用“(...) sad.gif...)”结构 127
3.6.7 善用大括号{ }缩小作用域 127
3.7 请使用goto语句 130
3.7.1 函数只有一个出口的原则需要goto 131
3.7.2 谁分配、谁释放的原则需要goto 131
3.7.3 商用工程要求goto 133
3.7.4 程序的易读性要求goto 135
3.7.5 break为什么不能乱用 136
3.7.6 goto的常规使用手法 138
3.8 指针的使用原则 139
3.8.1 商用数据传输常见的指针类型 139
3.8.2 不要使用两个以上的*号 141
3.8.3 指针不能参与四则运算 141
3.9 使用结构体的技巧 143
3.9.1 结构体传参的必要性 143
3.9.2 预防多重指针的隐患 145
3.9.3 32位到64位移植 145
3.9.4 弹性内存使用需要结构体传参 146
3.9.5 网络传输协议,需要结构体传参 148
3.10 使用宏的建议 150
3.10.1 宏的几大作用 150
3.10.2 c+ +的建议 151
3.10.3 编译宏——跨平台开发 152
3.11 回调函数设计方法 152
3.11.1 回调模型设计者 153
3.11.2 回调模型使用者 155
3.11.3 参数传递的常规手法 158
3.11.4 事件模型和回调模型 160
3.12 c语言字符串的深入研究 161
3.12.1 字符串拷贝 161
3.12.2 字符串构造 164
3.12.3 关于字符串处理的结论 166
3.13 c/c+ +语言无错化程序设计小结 166
第4章 设计自己的工程库 168
4.1 数据传输库中到底需要哪些模块 170
4.1.1 跨平台定义 170
4.1.2 锁与安全模块 170
4.1.3 内存池 171
4.1.4 资源管理池 171
4.1.5 线程池与任务池 171
4.1.6 队列管理 172
4.1.7 其他工具 172
4.2 工程库基础——跨平台定义 172
4.2.1 锁定义 172
4.2.2 线程控制相关定义 174
4.2.3 socket传输相关定义 175
4.2.4 include系统头文件 178
第5章 debug工具 180
5.1 变参函数的设计 182
5.2 文本输出 183
5.2.1 获得时间戳 184
5.2.2 同时输出到文件和屏幕 184
5.2.3 文本输出的原则 187
5.3 二进制输出的debug函数 188
5.4 核心debug和日志系统的区别 190
5.5 统计模块 191
5.5.1 累加器 192
5.5.2 计算模块 192
5.5.3 平均值计算 194
5.5.4 统计平均值计算 196
5.5.5 辅助功能函数 198
5.6 clowdebug工具类.. 200
5.6.1 需求分析 201
5.6.2 数据边界声明 201
5.6.3 类声明 202
5.6.4 类工具函数 204
5.6.5 业务函数 207
5.7 基本debug工具小结 210
第6章 锁 211
6.1 二元动作理论 213
6.1.1 二元动作在c语言中的书写特性 213
6.1.2 面向对象和面向过程的本质差异 216
6.1.3 二元动作在c++语言中的特殊要求 218
6.1.4 二元动作开发关注要点 219
6.2 锁对象 225
6.3 多线程安全的变量 226
6.3.1 cmint和cmbool试验 226
6.3.2 多线程安全的变量模板 230
6.4 单写多读锁 241
6.4.1 单写多读锁的来源 241
6.4.2 单写多读锁c语言实现 243
6.4.3 单写多读锁的c++实现 251
6.4.4 tonyxiaominsleep 252
6.4.5 单写多读锁安全变量 253
6.4.6 单写多读锁的真实意义 256
6.5 不可重入锁 258
6.5.1 需求分析 258
6.5.2 类实现 259
6.5.3 使用样例 260
6.6 线程控制锁 261
6.6.1 线程控制锁的实现 263
6.6.2 线程控制锁的使用 264
6.7 尽量不用锁 265
第7章 内存与资源管理 267
7.1 内存管理的基本要求 268
7.1.1 不泄露 268
7.1.2 不产生碎片 268
7.1.3 可以自动报警 269
7.2 内存池的核心逻辑——内存栈 270
7.2.1 内存管理的数学模型 270
7.2.2 管理模型的优化 272
7.2.3 关于链表管理的思考 273
7.2.4 内存块元素 276
7.2.5 内存栈 286
7.3 内存指针注册管理模块 292
7.3.1 内存注册模块原理介绍 293
7.3.2 模块设计及类声明 293
7.3.3 构造函数和析构函数 296
7.3.4 add函数 298
7.3.5 del函数 299
7.3.6 modeify函数 300
7.3.7 printinfo函数 301
7.3.8 内存注册模块的深入使用 301
7.4 socket注册管理模块 302
7.4.1 类声明 303
7.4.2 构造函数和析构函数 304
7.4.3 add函数 306
7.4.4 del函数 307
7.4.5 printinfo函数 308
7.5 内存池类 308
7.5.1 类声明 309
7.5.2 构造函数和析构函数 310
7.5.3 内存栈公有方法 312
7.5.4 指针管理方法 313
7.5.5 socket管理方法 314
7.5.6 printfinfo方法 315
7.6 内存管理的深层次含义 315
7.6.1 资源重用的理念 316
7.6.2 注册和反注册机制 316
7.6.3 静态资源的管理思路 316
7.7 被动池的常见组织形式 317
7.7.1 被动池的数据特性及需求分析 317
7.7.2 动态与静态被动池的差异性 318
7.7.3 静态被动池实施原理 318
7.7.4 被动池的常见组织形式 320
第8章 队列 322
8.1 为什么单说队列 323
8.1.1 网络同步的需求 323
8.1.2 协议信令排序的需求 323
8.1.3 存储转发的需求 324
8.1.4 异步转同步需要队列 325
8.1.5 负载均衡需要队列 325
8.1.6 等停需要队列 326
8.1.7 特例:实时转发不需要队列 326
8.2 几种常见的队列介绍 326
8.2.1 不是队列的队列cbuffer 327
8.2.2 静态队列popbuffer 327
8.2.3 动态队列menqueue 328
8.3 动态buffer类 328
8.3.1 编程思想的转变 328
8.3.2 buffer类的需求分析 332
8.3.3 buffer类声明 333
8.3.4 构造和析构函数 335
8.3.5 缓冲区大小设置函数 335
8.3.6 二进制拷贝函数 341
8.3.7 数值转换函数 342
8.3.8 二进制数据处理函数 344
8.3.9 文本字符串处理函数 345
8.3.10 数据比较函数 346
8.3.11 小结 347
8.4 静态buffer类 348
8.4.1 类声明 348
8.4.2 构造函数和析构函数 350
8.4.3 缓冲区设置函数 351
8.4.4 二进制拷贝函数 354
8.4.5 数值转换函数 356
8.4.6 二进制数据处理函数 357
8.4.7 文本字符串处理函数 358
8.4.8 数据比较函数 359
8.4.9 小结 359
8.5 popbuffer 360
8.5.1 popbuffer基本需求分析 360
8.5.2 基本数据结构介绍 361
8.5.3 基本类模型 363
8.5.4 构造函数和析构函数 365
8.5.5 工具服务函数 366
8.5.6 业务查询函数 368
8.5.7 添加addlast 370
8.5.8 提取getanddeletefirst 372
8.5.9 movealldata 376
8.5.10 popbuffer小结 378
8.5.11 popbuffer的不足 380
8.6 memqueue 381
8.6.1 动态队列的管理原则 381
8.6.2 基本数据结构介绍以及优化考虑 382
8.6.3 基本功能类声明 384
8.6.4 构造函数和析构函数 386
8.6.5 辅助工具函数 388
8.6.6 追加addlast 391
8.6.7 提取getanddeletefirst 395
8.6.8 popbuffer相关操作 398
8.6.9 文件保存相关操作 403
8.6.10 线程安全锁封装类 407
8.7 小结 413
第9章 时间片管理 415
9.1 多线程与单线程开发的差异 416
9.1.1 单任务操作系统运行程序的特点 416
9.1.2 任天堂游戏机中断机制 417
9.1.3 利用中断实现多任务 419
9.1.4 多任务操作系统运行程序的特点 422
9.1.5 多任务操作系统运行程序的机制 424
9.1.6 多任务运行环境的世界观 426
9.2 多任务操作系统常见线程操作 429
9.2.1 线程相关变量 429
9.2.2 线程函数声明 431
9.2.3 线程函数启动 433
9.2.4 min_sleep 433
9.2.5 线程操作总结 434
9.3 线程池 436
9.3.1 线程池的来源和需求分析 437
9.3.2 线程池的设计原理 440
9.3.3 线程池的基本数据结构 445
9.3.4 线程池的类设计说明 448
9.3.5 构造函数和析构函数 451
9.3.6 管理者线程 453
9.3.7 服务者线程 457
9.3.8 注册函数 460
9.3.9 线程池小结 463
9.4 任务池 466
9.4.1 任务池的原理分析 467
9.4.2 任务池的需求和设计 475
9.4.3 任务池的基本定义说明 478
9.4.4 任务池的类声明 480
9.4.5 构造函数和析构函数 482
9.4.6 管理者线程 484
9.4.7 服务者线程 485
9.4.8 任务注册接口 488
9.4.9 任务池的小结及实现示例 488
9.5 任务池的运行体 489
9.5.1 简化运行态 490
9.5.2 任务描述工具类 490
9.5.3 任务池运行体的设计原理 497
9.5.4 任务池运行体的类声明 499
9.5.5 starttask 501
9.5.6 stopall和printinfo 503
9.5.7 任务执行线程回调 503
9.5.8 任务池运行体小结及调用示例 505
9.6 时间片小结 507
第10章 log日志管理系统 509
10.1 日志管理系统需求分析 511
10.2 设计原理和边界定义 511
10.3 类声明 512
10.4 构造函数和析构函数 514
10.4.1 构造函数 514
10.4.2 析构函数 517
10.5 文件名控制逻辑 517
10.6 业务输出方法函数 521
10.7 log日志系统小结 525
第11章 聚合工具类 527
11.1 聚合工具类的类声明 529
11.2 聚合工具类函数说明 532
11.3 额外的话题:linux服务程序怎么写 538
11.3.1 服务器的开发习惯 538
11.3.2 linux的开发习惯 542
11.3.3 linux下开发服务程序的基本需求 543
11.3.4 基本设计原理 543
11.3.5 程序实战演示 546
11.3.6 程序使用说明 555
第12章 细节决定成败(代结束语) 556
12.1 工程实践注重细节 557
12.2 究竟怎样才能学好c和c++语言开发 558
12.3 如何做一名成功的软件工程师 559
12.4 关于网络数据传输 560
12.5 结束语... 560

正在读取……

这里是其它用户补充的资源(我也要补充):

暂无补充资源
正在加载,请稍等...

点击查看所有33网友评论

 

(?) [公告]留口水、评论相关规则 | [活动]每日签到 轻松领取电驴经验

    小贴士:
  1. 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
  2. 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
  3. 勿催片。请相信驴友们对分享是富有激情的,如果确有更新版本,您一定能搜索到。
  4. 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。
  5. 如果您发现自己的评论不见了,请参考以上4条。