豆瓣读书: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程序性能优化》之设计优化的更多相关文章

  1. [JAVA] java程序性能优化

    一.避免在循环条件中使用复杂表达式 在不做编译优化的情况下,在循环中,循环条件会被反复计算,如果不使用复杂表达式,而使循环条件值不变的话,程序将会运行的更快. 例子: import java.util ...

  2. Java程序性能优化技巧

    Java程序性能优化技巧 多线程.集合.网络编程.内存优化.缓冲..spring.设计模式.软件工程.编程思想 1.生成对象时,合理分配空间和大小new ArrayList(100); 2.优化for ...

  3. 《Java程序性能优化:让你的Java程序更快、更稳定》

    Java程序性能优化:让你的Java程序更快.更稳定, 卓越网更便宜,不错的书吧

  4. Java程序性能定位工具-火焰图

    Java程序性能定位工具-火焰图 前言 Java火焰图是一种新的查看CPU利用率方式.今天就带大家一起使用来自Google大神的工具来生成火焰图.火焰图非常的直观,问题一目了然,希望有一天它能成为JA ...

  5. 《Java程序性能优化》学习笔记 设计优化

    豆瓣读书:http://book.douban.com/subject/19969386/ 第一章 Java性能调优概述 1.性能的参考指标 执行时间: CPU时间: 内存分配: 磁盘吞吐量: 网络吞 ...

  6. java程序性能优化

    一.避免在循环条件中使用复杂表达式 在不做编译优化的情况下,在循环中,循环条件会被反复计算,如果不使用复杂表达式,而使循环条件值不变的话,程序将会运行的更快. 例子: import java.util ...

  7. Java程序性能优化——让你的java程序更快、更稳定

    1.Java性能调优概述 1.1.Web服务器,响应时间.吞吐量是两个重要的性能参数. 1.2.程序性能的几个表现: 执行速度:程序的反映是否迅速,响应时间是否足够短 内存分配:分配是否合理,是否过多 ...

  8. Java程序性能优化读书笔记(一):Java性能调优概述

    程序性能的主要表现点: 执行速度:程序的反映是否迅速,响应时间是否足够短 内存分配:内存分配是否合理,是否过多地消耗内存或者存在内存泄漏 启动时间:程序从运行到可以正常处理业务需要花费多少时间 负载承 ...

  9. Java程序性能优化之性能概述

    性能的基本概念 一).什么叫程序的性能? 程序运行所需的内存和时间. 二).性能的表现形式: 1).执行速度: 程序的反应是否迅速,响应时间是否足够短. 2).启动时间:程序从运行到可以处理正常业务所 ...

随机推荐

  1. python 爆破

    python 爆破 #!/usr/bin/python #-*- coding: GB2312 -*- #author:loversorry import urllib2 import urllib ...

  2. Windows句柄数限制

    设置 GDIProcessHandleQuota项设置GDI句柄数量,默认值为2710(16进制)/10000(10进制),该值的允许范围为 256 ~ 16384 ,将其调整为大于默认的10000的 ...

  3. 19. SpringBoot_web开发-使用外部Servlet容器&JSP支持

    還沒有web.xml,生  配置tomcat 嵌入式Servlet容器:应用打成可执行的jar 优点:简单.便携: 缺点:默认不支持JSP.优化定制比较复杂 使用定制器[ServerPropertie ...

  4. Java中BIO、NIO、AIO的区别和应用场景

    学习IO,首先要明白四个东西. 1.同步            java自己去处理io. 2.异步          java将io交给操作系统去处理,告诉缓存区大小,处理完成回调. 3.阻塞     ...

  5. text-decoration和text-indent和text-shadow

    text-decoration 属性规定添加到文本的修饰,规定划线的位置. <html> <head> <style type="text/css"& ...

  6. mysql gtid 第一篇

    GTID1 简介   就是全局事务ID(global transaction identifier )2 构成   uuid+transaction_id 3 格式  7a07cd08-ac1b-11 ...

  7. adb shell dumpsys meminfo [packagename] 输出内容的含义

    Private Dirty:私有的脏内存页(还在使用中)的大小:   Private Clean:私有的干净内存页(现在未使用了)的大小: 以上这二者相加,便是应用曾经申请过的内存空间大小.Priva ...

  8. weblogic基本目录介绍,位数查看,启动与发布项目,修改JVM参数,设置项目为默认项目

    这里的基本目录%base%表示安装目录,如我的目录为:E:/weblogic就是%base% 1.weblogic目录介绍 weblogic主要的目录介绍: 1.日志目录: 每个domain(域)都有 ...

  9. C++学习7-面向对象编程基础(多态性与虚函数、 IO文件流操作)

    多态 多态性是指对不同类的对象发出相同的消息将返回不同的行为,消息主要是指类的成员函数的调用,不同的行为是指不同的实现: 函数重载 函数重载是多态性的一种简单形式,它是指允许在相同的作用域内,相同的函 ...

  10. windows安装anaconda 报错failed to create anacoda menu ?

    windows安装anaconda 报错failed to create anacoda menu ? 装了无数次,每次都是 failed to create anacoda menu然后无选择忽略, ...