Java性能权威指南
查字典图书网
当前位置: 查字典 > 图书网 > 编程> Java性能权威指南

Java性能权威指南

8.3

作者:
出版社: 人民邮电出版社
原作名: Java Performance: The Definitive Guide
译者: 柳飞  |  陆明刚  |  臧秀涛
出版年: 2016-3-1
页数: 312
定价: CNY 79.00
装帧: 平装
ISBN: 9787115413765



推荐文章

猜你喜欢

附近的人在看

推荐阅读

拓展阅读

内容简介:

市面上介绍Java的书有很多,但专注于Java性能的并不多,能游刃有余地展示Java性能优化难点的更是凤毛麟角,本书即是其中之一。通过使用JVM和Java平台,以及Java语言和应用程序接口,本书详尽讲解了Java性能调优的相关知识,帮助读者深入理解Java平台性能的各个方面,最终使程序如虎添翼。

通过阅读本书,你可以:

运用四个基本原则最大程度地提升性能测试的效果

使用JDK中自带的工具收集Java应用的性能数据

理解JIT编译器的优缺点

调优JVM垃圾收集器以减少对程序的影响

学习管理堆内存和JVM原生内存的方法

了解如何最大程度地优化Java线程及同步的性能

解决Java EE和Java SE应用程序接口的性能问题

改善Java驱动的数据库应用程序的性能

作者简介:

Scott Oaks是Oracle公司的一位架构师,专注研究Oracle中间件软件的性能。加入Oracle之前,他曾于Sun Microsystem公司任职多年,在多个技术领域都有建树,包括SunOS的内核、网络程序设计、Windows系统的远程方法调用(RPC)以及 OPEN LOOK虚拟窗口管理器。1996年,Scott成为Sun公司的Java布道师,并于2001年加入Sun公司的Java性能小组——从那时起他就一直专注于Java的性能提升。此外,Scott也在O'Reilly出版社出版了多部书籍,包括Java Security、Java Threads、JXTA in a Nutshell和Jini in a Nutshell。

目录:

推荐序xi

前言xii

第1章 导论1

1.1 概述2

1.2 平台版本约定2

1.3 全面的性能调优4

1.3.1 编写更好的算法4

1.3.2 编写更少的代码4

1.3.3 老调重弹的过早优化5

1.3.4 其他:数据库很可能就是瓶颈6

1.3.5 常见的优化7

1.4 小结8

第2章 性能测试方法9

2.1 原则1:测试真实应用9

2.1.1 微基准测试9

2.1.2 宏基准测试13

2.1.3 介基准测试15

2.1.4 代码示例16

2.2 原则2:理解批处理流逝时间、吞吐量和响应时间19

2.2.1 批处理流逝时间19

2.2.2 吞吐量测试20

2.2.3 响应时间测试20

2.3 原则3:用统计方法应对性能的变化23

2.4 原则4:尽早频繁测试26

2.5 小结28

第3章 Java性能调优工具箱29

3.1 操作系统的工具和分析29

3.1.1 CPU使用率29

3.1.2 CPU运行队列32

3.1.3 磁盘使用率33

3.1.4 网络使用率34

3.2 Java监控工具35

3.2.1 基本的VM信息36

3.2.2 线程信息39

3.2.3 类信息39

3.2.4 实时GC分析39

3.2.5 事后堆转储39

3.3 性能分析工具39

3.3.1 采样分析器40

3.3.2 探查分析器41

3.3.3 阻塞方法和线程时间线42

3.3.4 本地分析器44

3.4 Java任务控制45

3.4.1 Java飞行记录器46

3.4.2 开启JFR52

3.4.3 选择JFR 事件54

3.5 小结56

第4章 JIT编译器58

4.1 JIT编译器:概览58

4.2 调优入门:选择编译器类型(Client、Server或二者同用)61

4.2.1 优化启动62

4.2.2 优化批处理63

4.2.3 优化长时间运行的应用64

4.3 Java和JIT编译器版本64

4.4 编译器中级调优67

4.4.1 调优代码缓存67

4.4.2 编译阈值68

4.4.3 检测编译过程70

4.5 高级编译器调优73

4.5.1 编译线程73

4.5.2 内联74

4.5.3 逃逸分析75

4.6 逆优化76

4.6.1 代码被丢弃77

4.6.2 逆优化僵尸代码78

4.7 分层编译级别79

4.8 小结80

第5章 垃圾收集入门81

5.1 垃圾收集概述81

5.1.1 分代垃圾收集器83

5.1.2 GC算法84

5.1.3 选择GC算法87

5.2 GC调优基础92

5.2.1 调整堆的大小92

5.2.2 代空间的调整95

5.2.3 永久代和元空间的调整96

5.2.4 控制并发97

5.2.5 自适应调整98

5.3 垃圾回收工具99

5.4 小结102

第6章 垃圾收集算法103

6.1 理解Throughput收集器103

6.2 理解CMS收集器109

6.2.1 针对并发模式失效的调优113

6.2.2 CMS收集器的永久代调优116

6.2.3 增量式CMS垃圾收集117

6.3 理解G1垃圾收集器118

6.4 高级调优126

6.4.1 晋升及Survivor空间126

6.4.2 分配大对象129

6.4.3 AggressiveHeap标志136

6.4.4 全盘掌控堆空间的大小137

6.5 小结138

第7章 堆内存最佳实践140

7.1 堆分析140

7.1.1 堆直方图141

7.1.2 堆转储142

7.1.3 内存溢出错误146

7.2 减少内存使用149

7.2.1 减少对象大小149

7.2.2 延迟初始化152

7.2.3 不可变对象和标准化对象156

7.2.4 字符串的保留157

7.3 对象生命周期管理160

7.3.1 对象重用160

7.3.2 弱引用、软引用与其他引用165

7.4 小结175

第8章 原生内存最佳实践176

8.1 内存占用176

8.1.1 测量内存占用177

8.1.2 内存占用最小化178

8.1.3 原生NIO缓冲区178

8.1.4 原生内存跟踪179

8.2 针对不同操作系统优化JVM182

8.2.1 大页182

8.2.2 压缩的oop185

8.3 小结187

第9章 线程与同步的性能188

9.1 线程池与ThreadPoolExecutor188

9.1.1 设置最大线程数189

9.1.2 设置最小线程数192

9.1.3 线程池任务大小193

9.1.4 设置ThreadPoolExecutor的大小193

9.2 ForkJoinPool195

9.3 线程同步201

9.3.1 同步的代价202

9.3.2 避免同步205

9.3.3 伪共享208

9.4 JVM线程调优211

9.4.1 调节线程栈大小211

9.4.2 偏向锁212

9.4.3 自旋锁212

9.4.4 线程优先级213

9.5 监控线程与锁213

9.5.1 查看线程214

9.5.2 查看阻塞线程214

9.6 小结217

第10章 Java EE 性能调优218

10.1 Web容器的基本性能218

10.2 线程池222

10.3 EJB会话Bean223

10.3.1 调优EJB对象池223

10.3.2 调优EJB缓存225

10.3.3 本地和远程实例226

10.4 XML和JSON处理227

10.4.1 数据大小227

10.4.2 解析和编组概述229

10.4.3 选择解析器230

10.4.4 XML验证235

10.4.5 文档模型237

10.4.6 Java对象模型240

10.5 对象序列化241

10.5.1 transient字段241

10.5.2 覆盖默认的序列化241

10.5.3 压缩序列化数据244

10.5.4 追踪对象复制246

10.6 Java EE网络API248

10.7 小结250

第11章 数据库性能的最佳实践251

11.1 JDBC251

11.1.1 JDBC驱动程序252

11.1.2 预处理语句和语句池253

11.1.3 JDBC连接池255

11.1.4 事务256

11.1.5 结果集的处理262

11.2 JPA264

11.2.1 事务处理264

11.2.2 对JPA的写性能进行优化267

11.2.3 对JPA的读性能进行优化268

11.2.4 JPA缓存271

11.2.5 JPA的只读实体276

11.3 小结277

第12章 Java SE API技巧278

12.1 缓冲式I/O278

12.2 类加载280

12.3 随机数284

12.4 Java原生接口285

12.5 异常287

12.6 字符串的性能290

12.7 日志291

12.8 Java集合类API292

12.8.1 同步还是非同步293

12.8.2 设定集合的大小294

12.8.3 集合与内存使用效率295

12.9 AggressiveOpts标志296

12.9.1 替代实现296

12.9.2 其他标志297

12.10 Lambda表达式和匿名类297

12.11 流和过滤器的性能300

12.12 小结302

附录A 性能调优标志摘要303

作者简介312

关于封面312

文章试读:本书基于Oracle HotSpot JVM 和Java Standard Edition(Java SE)7 和8。在发布版之间, Oracle 更新会定期发布更新版本。多数时候,更新版本只修订bug,不会加入语言新特性或者变更关键功能,但会更改调优标志的默认值。Oracle 很可能将在本书出版之后提供更新版本,当前版本为Java 7 update 40 和Java 8(迄今为止,还没有Java...

(查看全部试读)

展开全文
热门标签:
暂无评论
  • 大家都在看
  • 小编推荐
  • 猜你喜欢
  •