第 1章 性能指标 1
1.1 性能目标 1
1.2 性能指标 3
1.3 小结 4
第 2章 性能度量 5
2.1 性能度量方式 5
2.2 Windows内置工具 5
2.2.1 性能计数器 6
2.2.2 Windows事件追踪 10
2.3 时间分析器 20
2.3.1 Visual Studio采样分析器 20
2.3.2 Visual Studio检测分析器 24
2.3.3 时间分析器的gao级用法 25
2.4 内存分配分析器 27
2.4.1 Visual Studio内存分配
分析器 27
2.4.2 CLR分析器 29
2.5 内存分析器 34
2.5.1 ANTS Memory Profiler 34
2.5.2 SciTech .NET Memory
Profiler 36
2.6 其他分析器 38
2.6.1 数据库和数据访问
分析工具 38
2.6.2 并发分析工具 38
2.6.3 I/O分析工具 40
2.7 微基准测试 41
2.7.1 设计不佳的微基准测试
示例 41
2.7.2 微基准测试指南 44
2.8 小结 45
第3章 类型揭秘 47
3.1 示例 47
3.2 引用类型和值类型在语义上的
区别 48
3.3 存储、分配和销毁 48
3.4 引用类型揭秘 50
3.4.1 方法表 51
3.4.2 调用引用类型实例的方法 55
3.4.3 非虚方法的分发 56
3.4.4 静态方法和接口方法的
分发 58
3.4.5 同步块索引和lock
关键字 59
3.5 值类型揭秘 63
3.6 值类型的虚方法 65
3.7 装箱 65
3.7.1 避免在调用值类型的Equals
方法时产生装箱 67
3.7.2 GetHashCode方法 70
3.8 使用值类型的zui佳实践 72
3.9 小结 72
第4章 垃圾回收 73
4.1 为什么需要垃圾回收 73
4.1.1 空闲列表管理 73
4.1.2 引用计数垃圾回收 74
4.2 追踪垃圾回收 75
4.2.1 标记阶段 76
4.2.2 清理与压缩阶段 80
4.2.3 固定 82
4.3 垃圾回收器的特征 83
4.3.1 垃圾回收时暂停线程 83
4.3.2 在垃圾回收时挂起线程 83
4.3.3 工作站垃圾回收 85
4.3.4 服务器垃圾回收 86
4.3.5 切换垃圾回收特征 87
4.4 代 89
4.4.1 “代”模型的假设 89
4.4.2 .NET中“代”的实现 90
4.4.3 大对象堆 93
4.4.4 跨代引用 94
4.4.5 后台垃圾回收 96
4.5 垃圾回收段和虚拟内存 97
4.6 终结化 100
4.6.1 手动确定性终结化 100
4.6.2 自动的非确定性终结化 100
4.6.3 非确定性终结的缺点 102
4.6.4 Dispose模式 104
4.7 弱引用 106
4.8 使用垃圾回收器 108
4.8.1 System.GC类 108
4.8.2 使用CLR宿主与垃圾
回收器进行交互 111
4.8.3 垃圾回收触发器 111
4.9 垃圾回收性能zui佳实践 112
4.9.1 “代”模型 112
4.9.2 固定 113
4.9.3 终结化 114
4.9.4 其他建议与zui佳实践 114
4.10 小结 117
第5章 集合和泛型 119
5.1 泛型 119
5.1.1 .NET泛型 121
5.1.2 泛型约束 122
5.1.3 CLR泛型的实现 125
5.2 集合 131
5.2.1 并发集合 132
5.2.2 缓存 133
5.3 自定义集合 137
5.3.1 分离集(并查集) 137
5.3.2 跳跃表 138
5.3.3 一次性集合 139
5.4 小结 141
第6章 并发和并行 142
6.1 挑战与所得 142
6.2 从线程到线程池,再到任务 143
6.2.1 任务并行 148
6.2.2 数据并行 153
6.2.3 C# 5异步方法 156
6.2.4 TPL中的gao级模式 159
6.3 同步 160
6.3.1 无锁代码 161
6.3.2 Windows同步机制 165
6.3.3 缓存 167
6.4 通用的GPU计算 168
6.4.1 C++ AMP简介 169
6.4.2 矩阵相乘 171
6.4.3 多体仿真 171
6.4.4 tile和共享内存 172
6.5 小结 175
第7章 网络、I/O和序列化 176
7.1 I/O基本概念 176
7.1.1 同步与异步I/O 176
7.1.2 I/O完成端口 177
7.1.3 .NET线程池 181
7.1.4 内存复制 181
7.2 分散-聚集I/O 182
7.3 文件I/O 182
7.3.1 缓存提示 183
7.3.2 非缓存I/O 183
7.4 网络I/O 184
7.4.1 网络协议 184
7.4.2 网络套接字 185
7.5 数据序列化与反序列化 186
7.5.1 序列化基准测试 187
7.5.2 数据集(DataSet)
序列化 189
7.6 Windows通信基础类库 189
7.6.1 限流 189
7.6.2 处理模型 190
7.6.3 缓存 191
7.6.4 异步WCF客户端与
服务器 191
7.6.5 绑定 192
7.7 小结 193
第8章 不安全的代码以及互操作 194
8.1 不安全的代码 194
8.1.1 对象固定与垃圾回收
句柄 195
8.1.2 生存期管理 196
8.1.3 分配非托管内存 196
8.1.4 内存池 197
8.2 平台调用 198
8.2.1 PInvoke.net与P/Invoke
Interop Assistant软件 199
8.2.2 绑定 200
8.2.3 列集器存根程序 201
8.2.4 原生同构类型 204
8.2.5 列集方向、值类型和引用
类型的列集 205
8.2.6 代码访问安全性 206
8.3 COM互操作性 206
8.3.1 生存期管理 207
8.3.2 单元列集 208
8.3.3 TLB导入与代码访问
安全性 209
8.3.4 无主互操作程序集
(NoPIA) 209
8.3.5 异常 210
8.4 C++/CLI语言扩展 211
8.4.1 marshal_as辅助库 213
8.4.2 IL代码与原生代码 214
8.5 Windows 8 WinRT互操作 214
8.6 互操作的zui佳实践 215
8.7 小结 215
第9章 算法优化 216
9.1 复杂度的维度 216
9.1.1 大O复杂度 216
9.1.2 主定理 217
9.1.3 图灵机与复杂度分类 218
9.1.4 停机问题 219
9.1.5 NP完全问题 221
9.1.6 记忆与动态规划 221
9.1.7 编辑距离 222
9.1.8 每对顶点间的zui短路径 224
9.2 近似算法 226
9.2.1 旅行商问题 226
9.2.2 zui大割 227
9.3 概率算法 227
9.3.1 概率zui大割 227
9.3.2 费马质数测试 228
9.4 索引与压缩 228
9.4.1 变量的长度编码 228
9.4.2 压缩索引 229
9.5 小结 230
第 10章 性能模式 232
10.1 JIT编译器优化 232
10.1.1 标准的优化方法 232
10.1.2 方法内联 233
10.1.3 消除边界检查 234
10.1.4 尾调用 236
10.1.5 启动性能 238
10.1.6 使用NGen进行JIT预
编译 239
10.1.7 多核后台JIT编译 241
10.2 关于启动性能的其他技巧 243
10.2.1 将强命名程序集置于
GAC中 243
10.2.2 防止本机镜像发生地址
重排 243
10.2.3 减少程序集数目 244
10.3 处理器相关的优化 245
10.3.1 单指令多数据流
(SIMD) 245
10.3.2 指令级别并行 247
10.4 异常 250
10.5 反射 250
10.6 代码生成 251
10.6.1 直接用源代码生成
代码 251
10.6.2 用动态轻量级代码生成技
术(LCG)生成代码 253
10.7 小结 257
第 11章 Web应用性能 258
11.1 测试Web应用的性能 258
11.1.1 Visual Studio Web性能
测试和压力测试 259
11.1.2 HTTP监控工具 260
11.1.3 分析工具 260
11.2 提高Web服务器的性能 261
11.2.1 缓存公用对象 261
11.2.2 使用异步页面、模块和
控制器 262
11.2.3 创建异步页面 263
11.2.4 创建异步控制器 265
11.3 ASP.NET环境调优 265
11.3.1 关闭ASP.NET跟踪和调试 266
11.3.2 关闭视图状态 267
11.3.3 服务端输出缓存 268
11.3.4 对ASP.NET应用程序进行预编译 269
11.3.5 ASP.NET进程模型调优 270
11.4 配置IIS 271
11.4.1 输出缓存 271
11.4.2 应用程序池配置 273
11.5 网络优化 274
11.5.1 使用HTTP缓存头 274
11.5.2 启用IIS压缩 277
11.5.3 精简与合并 279
11.5.4 使用内容发布网络 (CDN) 280
11.6 对ASP.NET应用程序进行扩容(scaling) 281
11.6.1 向外扩容 281
11.6.2 ASP.NET扩容机制 282
11.6.3 向外扩容的隐患 282
11.7 小结 283
· · · · · · (
收起)