书籍详情
大话Java性能优化
作者:周明耀
出版社:电子工业出版社
出版时间:2016-04-01
ISBN:9787121284816
定价:¥89.00
购买这本书可以去
内容简介
本书主要提供Java性能调优方面的参考建议及经验交流。作者力求做到知识的综合传播,而不是仅仅只针对Java虚拟机调优进行讲解,另外力求每一章节都有实际的案例支撑。具体包括:性能优化策略、程序编写及硬件服务器的基础知识、Java API优化建议、算法类程序的优化建议、并行计算优化建议、Java程序性能监控及检测、JVM原理知识、其他相关优化知识等。通读本书后,读者可以深入了解Java性能调优的许多主题及相关的综合性知识。读者也可以把本书作为参考,对于感兴趣的主题,直接跳到相应章节寻找答案。总的来说,性能调优在很大程度上是一门艺术,解决的Java性能问题越多,技艺才会越精湛。我们不仅要关心JVM的持续演进,也要积极地去了解底层的硬件平台和操作系统的进步。
作者简介
12年投资银行项目、分布式计算项目工作经验,IBM开发者论坛专家作者。一名IT技术狂热爱好者,一名顽强到底的工程师。我推崇技术创新、思维创新,对于新技术非常的热爱,致力于技术研发、研究,通过发布文章、书籍、互动活动的形式积极推广软件技术。 欢迎添加作者微信“michael_tec”,共同探讨IT技术话题。
目录
第1章 性能调优策略概述 11.1 为什么需要调优 11.2 性能优化的参考因素 51.2.1 传统计算机体系的分歧 51.2.2 导致系统瓶颈的计算资源 71.2.3 程序性能衡量指标 81.2.4 性能优化目标 91.2.5 性能优化策略 101.3 性能调优分类方法 111.3.1 业务方面 121.3.2 基础技术方面 121.3.3 组件方面 171.3.4 架构方面 191.3.5 层次方面 201.4 本章小结 21第2章 优化前的准备知识 222.1 服务器知识 232.1.1 内存 232.1.2 GPU/CPU 442.1.3 硬盘 492.1.4 网络架构 512.2 新兴技术 53第3章 Java API调用优化建议 543.1 面向对象及基础类型 553.1.1 采用Clone()方式创建对象 553.1.2 避免对boolean判断 553.1.3 多用条件操作符 563.1.4 静态方法代替实例方法 563.1.5 有条件地使用final关键字 583.1.6 避免不需要的instanceof操作 583.1.7 避免子类中存在父类转换 593.1.8 建议多使用局部变量 603.1.9 运算效率最高的方式——位运算 603.1.10 用一维数组代替二维数组 623.1.11 布尔运算代替位运算 643.1.12 提取表达式优化 653.1.13 不要总是使用取反操作符(!) 663.1.14 不要重复初始化变量 663.1.15 变量初始化过程思考 663.1.16 对象的创建、访问过程 693.1.17 在switch语句中使用字符串 703.1.18 数值字面量的改进 733.1.19 优化变长参数的方法调用 743.1.20 针对基本数据类型的优化 753.1.21 空变量 763.2 集合类概念 773.2.1 快速删除List里面的数据 783.2.2 集合内部避免返回null 803.2.3 ArrayList、LinkedList比较 823.2.4 Vector、HashTable比较 853.2.5 HashMap使用经验 873.2.6 EnumSet、EnumMap 913.2.7 HashSet使用经验 923.2.8 LinkedHashMap、TreeMap比较 963.2.9 集合处理优化新方案 993.2.10 优先考虑并行计算 1073.3 字符串概念 1083.3.1 String对象 1083.3.2 善用String对象的SubString方法 1113.3.3 用charat()代替startswith() 1133.3.4 在字符串相加的时候,使用' '代替" " 1143.3.5 字符串切割 1143.3.6 字符串重编码 1173.3.7 合并字符串 1183.3.8 正则表达式不是万能的 1223.4 引用类型概念 1233.4.1 强引用(Strong Reference) 1263.4.2 软引用(Soft Reference) 1313.4.3 弱引用(Weak Reference) 1353.4.4 引用队列 1413.4.5 虚引用(Phantom Reference) 1423.5 其他相关概念 1463.5.1 JNI技术提升 1463.5.2 异常捕获机制 1503.5.3 ExceptionUtils类 1543.5.4 循环技巧 1553.5.5 替换switch 1573.5.6 优化循环 1583.5.7 使用arrayCopy() 1593.5.8 使用Buffer进行I/O操作 1613.5.9 使用clone()代替new 1643.5.10 I/O速度 1663.5.11 Finally方法里面释放或者关闭资源占用 1673.5.12 资源管理机制 1673.5.13 牺牲CPU时间 1693.5.14 对象操作 1723.5.15 正则表达式 1723.5.16 压缩文件处理 1743.6 本章小结 175第4章 程序设计优化建议 1764.1 算法优化概述 1764.1.1 常用算法逻辑描述 1774.1.2 多核算法优化原理 1864.1.3 Java算法优化实践 1884.2 设计模式 1964.2.1 设计模式的六大准则 1964.2.2 单一对象控制 2004.2.3 并行程序设计模式 2024.2.4 接口适配 2054.2.5 访问方式隔离 2194.3 I/O及网络相关优化 2254.3.1 I/O操作优化 2254.3.2 Socket编程 2314.3.3 NIO 2.0文件系统 2354.4 数据应用优化 2364.4.1 关系型数据库优化 2364.4.2 向HBase插入大量数据 2404.4.3 解决海量数据缓存 2514.5 其他优化 2564.5.1 Web系统性能优化建议 2564.5.2 死锁情况解决方案 2594.5.3 JavaBeans组件 2684.6 本章小结 269第5章 Java并行程序优化建议 2705.1 并行程序优化概述 2705.1.1 资源限制带来的挑战 2715.1.2 进程、线程、协程 2725.1.3 使用多线程的原因 2815.1.4 线程不安全范例 2825.1.5 重排序机制 2845.1.6 实例变量的数据共享 2865.1.7 生产者与消费者模式 2885.1.8 线程池的使用 2905.2 锁机制对比 2965.2.1 锁机制概述 2965.2.2 Synchronized使用技巧 2985.2.3 Volatile的使用技巧 3035.2.4 队列同步器 3045.2.5 可重入锁 3075.2.6 读写锁 3085.2.7 偏向锁和轻量级锁 3095.3 增加程序并行性 3105.3.1 并发计数器 3115.3.2 减少上下文切换次数 3125.3.3 针对Thread类的更新 3145.3.4 Fork/Join框架 3145.3.5 Executor框架 3185.4 JDK类库使用 3195.4.1 原子值 3205.4.2 并行容器 3245.4.3 非阻塞队列 3325.4.4 阻塞队列 3385.4.5 并发工具类 3655.5 本章小结 376第6章 JVM性能测试及监控 3776.1 监控计算机设备层 3786.1.1 监控CPU 3806.1.2 监控内存 4056.1.3 监控磁盘 4176.1.4 监控网络 4236.2 监控JVM活动 4286.2.1 监控垃圾收集目的 4296.2.2 GC垃圾回收报告分析 4306.2.3 图形化工具 4316.2.4 GC跟踪示例 4376.3 本章小结 438第7章 JVM性能调优建议 4397.1 JVM相关概念 4397.1.1 内存使用相关概念 4407.1.2 字节码相关知识 4437.1.3 自动内存管理 4487.2 JVM系统架构 4517.2.1 JVM的基本架构 4517.2.2 JVM初始化过程 4537.2.3 JVM架构模型与执行引擎 4567.2.4 解释器与JIT编译器 4567.2.5 类加载机制 4577.2.6 虚拟机 4587.3 垃圾回收机制相关 4597.3.1 GC相关概念 4597.3.2 垃圾回收算法 4687.3.3 垃圾收集器 4767.4 实用JVM实验 4907.4.1 将新对象预留在年轻代 4907.4.2 大对象进入年老代 4947.4.3 设置对象进入年老代的年龄 4957.4.4 稳定与震荡的堆大小 4977.4.5 吞吐量优先案例 4987.4.6 使用大页案例 4997.4.7 降低停顿案例 4997.4.8 设置最大堆内存 4997.4.9 设置最小堆内存 5007.4.10 设置年轻代 5037.4.11 设置持久代 5047.4.12 设置线程栈 5047.4.13 堆的比例分配 5057.4.14 堆分配参数总结 5087.4.15 垃圾回收器相关参数总结 5097.4.16 查询GC命令 5157.5 本章小结 515第8章 其他优化建议 5168.1 Java现有机制及未来发展 5168.1.1 Java体系结构变化历史 5168.1.2 Java语言面临的挑战 5208.1.3 Java 8的新特性 5228.1.4 Java语言前景 5238.1.5 物联网:Java和你是一对 5248.1.6 Java模块化发展 5258.1.7 OpenJDK的发展 5278.2 系统架构优化建议 5288.2.1 系统架构调优 5288.2.2 Java项目优化方式分享 5308.2.3 面向服务架构 5348.2.4 程序隔离技术 5388.2.5 团队并行开发准则 5448.3 与编程无关 5468.3.1 工程师品格 5468.3.2 如何成为技术大牛 5478.3.3 编程方法分享 5488.4 本章小结 549
猜您喜欢