《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] java程序性能优化
一.避免在循环条件中使用复杂表达式 在不做编译优化的情况下,在循环中,循环条件会被反复计算,如果不使用复杂表达式,而使循环条件值不变的话,程序将会运行的更快. 例子: import java.util ...
- Java程序性能优化技巧
Java程序性能优化技巧 多线程.集合.网络编程.内存优化.缓冲..spring.设计模式.软件工程.编程思想 1.生成对象时,合理分配空间和大小new ArrayList(100); 2.优化for ...
- 《Java程序性能优化:让你的Java程序更快、更稳定》
Java程序性能优化:让你的Java程序更快.更稳定, 卓越网更便宜,不错的书吧
- Java程序性能定位工具-火焰图
Java程序性能定位工具-火焰图 前言 Java火焰图是一种新的查看CPU利用率方式.今天就带大家一起使用来自Google大神的工具来生成火焰图.火焰图非常的直观,问题一目了然,希望有一天它能成为JA ...
- 《Java程序性能优化》学习笔记 设计优化
豆瓣读书:http://book.douban.com/subject/19969386/ 第一章 Java性能调优概述 1.性能的参考指标 执行时间: CPU时间: 内存分配: 磁盘吞吐量: 网络吞 ...
- java程序性能优化
一.避免在循环条件中使用复杂表达式 在不做编译优化的情况下,在循环中,循环条件会被反复计算,如果不使用复杂表达式,而使循环条件值不变的话,程序将会运行的更快. 例子: import java.util ...
- Java程序性能优化——让你的java程序更快、更稳定
1.Java性能调优概述 1.1.Web服务器,响应时间.吞吐量是两个重要的性能参数. 1.2.程序性能的几个表现: 执行速度:程序的反映是否迅速,响应时间是否足够短 内存分配:分配是否合理,是否过多 ...
- Java程序性能优化读书笔记(一):Java性能调优概述
程序性能的主要表现点: 执行速度:程序的反映是否迅速,响应时间是否足够短 内存分配:内存分配是否合理,是否过多地消耗内存或者存在内存泄漏 启动时间:程序从运行到可以正常处理业务需要花费多少时间 负载承 ...
- Java程序性能优化之性能概述
性能的基本概念 一).什么叫程序的性能? 程序运行所需的内存和时间. 二).性能的表现形式: 1).执行速度: 程序的反应是否迅速,响应时间是否足够短. 2).启动时间:程序从运行到可以处理正常业务所 ...
随机推荐
- npm install报错node-sass
1.node-sass安装错误 Building: C:\Program Files\nodejs\node.exe D:\gitlab\coreui\node_modules\node-gyp\bi ...
- LaTeX简历模板
%# -*- coding:utf-8 -*- %% start of file `template_en.tex'. %% Copyright 2006-1008 Xavier Danaux (xd ...
- URL基本结构
先来简单说下URI.URL.URN这三个鬼东西. URI全称Uniform Resource Identifier,统一资源标识符 URL全称Uniform Resource Locator,统一资源 ...
- 01、@ConfigurationProperties 将属性文件里的值映射到JavaBean
@ConfigurationProperties("person") //或是prefix属性 @Component //必须注册成容器中的bean被容器管理起来 public c ...
- 实例详析ImageView的adjustViewBonds和scaleType
android:adjustViewBounds是否保持宽高比.需要与maxWidth.MaxHeight一起使用,否则单独使用没有效果. 设置View的最大高度,单独使用无效,需要与setAdjus ...
- 【python图像处理】图像的缩放、旋转与翻转
[python图像处理]图像的缩放.旋转与翻转 图像的几何变换,如缩放.旋转和翻转等,在图像处理中扮演着重要的角色,python中的Image类分别提供了这些操作的接口函数,下面进行逐一介绍. 1.图 ...
- ubuntu16.04安装opencv2.4.13
1.更新 sudo apt-get update sudo apt-get upgrade 2.安装关联库 2.1 搭建C/C++编译环境 sudo apt-get install build-ess ...
- 无责任共享 Coursera、Udacity 等课程视频(转载)
转载链接:https://www.zybuluo.com/illuz/note/71868 B站计划:https://www.zybuluo.com/illuz/note/832995#cs基础课程
- 在全志平台调试博通的wifi驱动(类似ap6212)【转】
转自:http://blog.csdn.net/fenzhi1988/article/details/44809779 调试驱动之前,首先先看看驱动代码,了解代码大致工作流程,再根据硬件配置驱动,比如 ...
- 001_深度剖析什么是 SLI、SLO和SLA?
前言 SLO和SLA是大家常见的两个名词:服务等级目标和服务等级协议. 云计算时代,各大云服务提供商都发布有自己服务的SLA条款,比如Amazon的EC2和S3服务都有相应的SLA条款.这些大公司的S ...