第八章:软件构造的性能
第二节:动态程序分析方法与工具
问题一:性能调优的工具
1.命令行分析工具(Command-line profiling tools)
①jstat:获取JVM的heap使用和GC的性能统计数据
②jmap:输出内存中的对象分布情况
③jhat:导出heap dump,浏览/查询其中的对象分布情况
④jstack:获取Java线程的stacktrace(用途:定位线程出现长时间停顿的原因,如多线程间死锁、死循环、请求外部资源导致的长时间等待等。线程出现停顿的时候通过jstack来查看各个线程的调用堆栈,就可以知道没有响应的线程到底在后台做什么事情,或者等待什么资源。)
2.JConsole(GUI监控工具)
3.Visual VM
4.MAT(Eclipse Memory Analyzer)
含义:是内存堆导出文件的分析工具
Memory leak analysis:
对问题发生时刻的系统内存状态获取一个整体印象。 找到最有可能导致内存泄露的元凶,通常是消耗内存最多的对象 进一步查看内存消耗最大的类/对象的具体情况,看是否有异常行为。