《Java程序性能优化》学习笔记 设计优化
豆瓣读书:http://book.douban.com/subject/19969386/
第一章 Java性能调优概述
1.性能的参考指标
执行时间:
CPU时间:
内存分配:
磁盘吞吐量:
网络吞吐量:
响应时间:
2.木桶定律
系统的最终性能取决于系统中性能表现最差的组件,例如window系统内置的评分就是选取最低分。可能成为系统瓶颈的计算资源如,磁盘I/O,异常,数据库,锁竞争,内存等。
性能优化的几个方面,如设计优化,Java程序优化,并行程序开发及优化,JVM调优,Java性能调优工具的使用等。
3.Amdahl定律
加速比=优化前系统耗时/优化后系统耗时,加速比越高,表明优化效果越好。
单纯增加处理器数量对提升系统性能意义不大,必须同时提高程序的并行化比重。
第二章 设计优化
2.2 常用优化组件和方法
1.缓冲Buffer
缓冲最常用的场景就是提高I/O的速度。JDK很多IO组件都提供了缓冲功能。
如:
//Writer writer=new FileWriter(new File("file.txt"));
Writer writer=new BufferedWriter(new FileWriter(new File("file.txt")),2000);
//包装过后效率大概相差接近一倍
long begin=System.currentTimeMillis();
for(int i=0;i<10000;i++){
writer.write(i);
}
writer.close();
System.out.print("Spend:"+(System.currentTimeMillis()-begin));
BufferedWriter对象拥有两个构造函数:
public BufferedWriter(Writer out);
public BufferedWriter(Writer out,int sz);
第一个将默认构造大小为8K的缓冲区,第二个允许在应用层指定缓冲区的大小。
缓冲区不宜过大,也不宜过小。
同样,BufferedOutputStream可以包装所有的OutputStream,为其提供缓冲功能,提高输出流的效率。
缓冲区对任何一种上下层组件存在性能差异的场合都可以起到很好的效果,典型的例子是,
使用缓冲区提升动画显示效果。
2.缓存
缓存也是一块为提升系统性能而开辟的内存空间,暂存数据处理结果,并提供下次访问使用。
目前有许多优秀的缓存工具可供使用。
3.对象复用——“池”
对象池化,核心思想是,如果一个类被频繁的请求使用,不必每次都生成一个实例,可以保存在“池”中,需要时直接获取。
典型的如线程池和数据库连接池。
4.并行替代串行
5.负载均衡
负载均衡的典型实现是Tomcat集群,配置Tomcat集群实现负载均衡,可以通过Apache服务器实现。即使用Apache服务器作为负载分配器,将请求转向各个Tomcat服务器。
两种基本的Session共享模式。黏性Session模式和复制Session模式。
黏性Session模式下,所有的Session信息被平均分配到各个Tomcat节点上,但是节点宕机,其所维护的session信息将丢失,不具备高可用性,同一个用户只能与一台Tomcat交互。
复制session,使得所有session在所有Tomcat节点上保持一致。一个节点的session被修改,会被广播到其他节点上,保持同步。
《Java程序性能优化》学习笔记 设计优化的更多相关文章
- Java程序猿JavaScript学习笔记(14——扩大jQuery UI)
计划和完成这个例子中,音符的顺序如下: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScr ...
- Java程序猿JavaScript学习笔记(2——复制和继承财产)
计划和完成在这个例子中,音符的以下序列: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaSc ...
- Java程序猿JavaScript学习笔记(4——关闭/getter/setter)
计划和完成这个例子中,音符的顺序如下: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScr ...
- Java程序性能优化读书笔记(一):Java性能调优概述
程序性能的主要表现点: 执行速度:程序的反映是否迅速,响应时间是否足够短 内存分配:内存分配是否合理,是否过多地消耗内存或者存在内存泄漏 启动时间:程序从运行到可以正常处理业务需要花费多少时间 负载承 ...
- [JAVA] java程序性能优化
一.避免在循环条件中使用复杂表达式 在不做编译优化的情况下,在循环中,循环条件会被反复计算,如果不使用复杂表达式,而使循环条件值不变的话,程序将会运行的更快. 例子: import java.util ...
- Java程序性能优化技巧
Java程序性能优化技巧 多线程.集合.网络编程.内存优化.缓冲..spring.设计模式.软件工程.编程思想 1.生成对象时,合理分配空间和大小new ArrayList(100); 2.优化for ...
- 《Java程序性能优化:让你的Java程序更快、更稳定》
Java程序性能优化:让你的Java程序更快.更稳定, 卓越网更便宜,不错的书吧
- Pandas 性能优化 学习笔记
摘要 本文介绍了使用 Pandas 进行数据挖掘时常用的加速技巧. 实验环境 import numpy as np import pandas as pd print(np.__version__) ...
- 智能SQL优化工具--SQL Optimizer for SQL Server(帮助提升数据库应用程序性能,最大程度地自动优化你的SQL语句 )
SQL Optimizer for SQL Server 帮助提升数据库应用程序性能,最大程度地自动优化你的SQL语句 SQL Optimizer for SQL Server 让 SQL Serve ...
随机推荐
- 微型 ORM-FluentData 温故知新系列
http://www.cnblogs.com/_popc/archive/2012/12/26/2834726.html 引言:FluentData 是微型 ORM(micro-ORM)家族的一名新成 ...
- jQuery中prop()函数控制多选框(全选,反选)
今天看了jQuery手册,对prop()函数又多了一点认识,记忆力不好,记录下来. prop() : 获取匹配元素集中第一个元素的值 判断checkbox中的第一个是否被选中: $(":ch ...
- php中文字符串翻转
转自:http://www.oschina.net/code/snippet_613962_17070 <?php header("content-type:text/html;cha ...
- Linux rpm 命令参数使用详解[介绍和应用](转)
RPM是RedHat Package Manager(RedHat软件包管理工具)类似Windows里面的“添加/删除程序” rpm 执行安装包二进制包(Binary)以及源代码包(Source)两种 ...
- 重温设计模式(三)——职责链模式(chain of responsibility)
一. 写在前面的 这么多的设计模式,我觉得职责链是我第一次看上去最简单,可是回想起来却又最复杂的一个模式. 因此,这个文章我酝酿了很久,一直也没有胆量发出来,例子也是改了又改,可是仍然觉得不够合理.所 ...
- swift中文文档- 类型转换
未翻译完 待续(英语烂,求斧正) Type Casting 类型转换 Type casting is a way to check the type of an instance, and/or to ...
- android TP驱动移植调试笔记(转)
1. 添加I2C 设备 TP 一般采用的是I2C 作为数据和命令接口,所以TP 驱动也可以归类为I2C 驱动.TP驱动的主要逻辑不在这里,但是了解了Linux 的I2C 体系架构,就可以对整个驱动流程 ...
- webexam项目杂记2
strstr,stristr是返回匹配到的字符串,常规的字符串操作尽量避免使用正则, strstr是返回从匹配字符(串)开始(包括该匹配字符串)到结束的(或开头的)字符串 而如果仅仅只是判断是否包含匹 ...
- Mate7微信指纹支付来了 比Touch ID整合微信早一点
之前我们聊过微信将推指纹支付 "指付通"会与Touch ID整合吗这个话题,现在有国内厂商率先支持微信指纹支付,体验一下美国用户使用Apple Pay搭配Touch ID来实现便捷 ...
- Stockbroker Grapevine(floyd)
Stockbroker Grapevine Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 28231 Accepted: ...