大话Java性能优化 版权信息
- ISBN:9787121284816
- 条形码:9787121284816 ; 978-7-121-28481-6
- 装帧:暂无
- 册数:暂无
- 重量:暂无
- 所属分类:>>
大话Java性能优化 本书特色
本书主要提供java性能调优方面的参考建议及经验交流。作者力求做到知识的综合传播,而不是仅仅只针对java虚拟机调优进行讲解,另外力求每一章节都有实际的案例支撑。具体包括:性能优化策略、程序编写及硬件服务器的基础知识、java api优化建议、算法类程序的优化建议、并行计算优化建议、java程序性能监控及检测、jvm原理知识、其他相关优化知识等。
通读本书后,读者可以深入了解java性能调优的许多主题及相关的综合性知识。读者也可以把本书作为参考,对于感兴趣的主题,直接跳到相应章节寻找答案。
总的来说,性能调优在很大程度上是一门艺术,解决的java性能问题越多,技艺才会越精湛。我们不仅要关心jvm的持续演进,也要积极地去了解底层的硬件平台和操作系统的进步。
大话Java性能优化 内容简介
1、系统介绍系统调优的解决思路和技术实现
2、结合大家*为熟知的12306、电商等案例
3、架构、设计、开发、算法等多层次多角度思路和策略
4、涉及内存、io等各种问题,提供丰富的经验参考
5、语言通俗易懂,引人入胜
大话Java性能优化 目录
第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
展开全部
大话Java性能优化 相关资料
系统调优在软件的后续改进和重构中占有很大的地位,能够弥补前述的不足,本书以通俗的语言和引人入胜的故事,重点讲述软件性能调优的方法论和具体实现路径,读者可以根据自己的实际情况进行参照比对,就像进了兵器库挑选合适自己的顺手武器。程序凑合着上线是一回事,而在压力下能够优美地运行往往很不容易。本书对于所有有志于进行软件高级管理的人员而言,具有非常重要的意义。
——海适云承ceo兼首席架构师 沈英桓(sam shen)当我翻开周明耀先生编写的《大话java性能优化》这本书时,一下子被他生动朴实的语言所深深吸引,他将生硬、深奥的it系统技术问题深入浅出地层层剥开,娓娓道来,并结合时下大家最为熟知的12306、电商等案例,系统地分析和介绍了系统调优的重要性、解决思路和技术实现。作为金融it的一名同行,我对系统性能对用户体验和业务处理的重要性深有体会,尤其是高频交易系统(hft),对系统性能的要求近乎苛刻,对业务的处理和响应要求毫秒级。本书作者从系统架构、系统设计、开发、编码、算法等多层次多角度提供思路和优化策略,是一本很务实的技术贴,值得大家学习、借鉴和探讨。
——德意志银行(中国)有限公司环球科技运营经理 黄正兵在我自己使用java开发项目的过程中,经常会切实地感受到系统调优的重要性。然而java性能调优并不是一项一蹴而就的简单任务,而是如同并发编程需要关注算法、内存、i/o等各种问题以及丰富的经验积累。本书中作者结合自己的实践经验总结了一些性能优化的方案。这些经验涉及java基本语法、对象和引用、string类型和集合类的使用等各个方面且附有示例,使人受益匪浅,如果能够将其灵活运用到自己的系统中,相信能够对读者处理性能优化问题提供不小的帮助。此外,作者看待性能优化问题的视角相对开阔,系统且详尽地讨论了可能导致性能问题的各个环节和不同角度下性能优化的问题,读后令人豁然开朗。
——西安工业大学2016应届硕士毕业生 fenny
大话Java性能优化 作者简介
周明耀,12年投资银行项目、分布式计算项目工作经验,IBM开发者论坛专家作者。一名IT技术狂热爱好者,一名顽强到底的工程师。推崇技术创新、思维创新,对于新技术非常的热爱,致力于技术研发、研究,通过发布文章、书籍、互动活动的形式积极推广软件技术。欢迎添加作者微信“michael_tec”,共同探讨IT技术话题。