Java编程中的性能优化如何实现?

Java编程中的性能优化如何实现?,第1张

性能优化我觉得应该分两步走,第一步:寻找性能瓶颈,第二步:性能调优;

下面分别进行分析:

第一步:寻找性能瓶颈

通常性能瓶颈的表象是资源消耗过多、外部处理系统的性能不足;或者资源消耗不多,但是程序效应还是很慢;

资源主要消耗在cpu,文件io,网络io以及内存方面,当某一资源消耗过多会造成系统响应慢;

外部处理系统的性能不足主要是所调用其他系统提供的功能或数据库的响应速度不够,外部系统慢可能也是资源消耗过多导致,数据库响应慢可以对数据库进行调优;

资源消耗不多但仍然慢主要原因是程序代码运行效率不高,未充分使用资源或程序结构不合理;

1.1cpu消耗分析

可以通过相关命令比如top,pidstat,找出各个类型消耗cpu的占比,最常见的就是us和sy类型分别代表用户进程消耗和线程间切换消耗;如果us过高可以找到相关的线程ID然后分析代码;如果sy过高是不是启动了过多的线程导致线程切换过多;

1.2文件io消耗

要跟踪线程的文件IO消耗,可以通过pidstat来查找,可以查到每秒的读写kb数;找到读写kb数多个线程,然后结合jstack找到相关的java代码,然后分析;

1.3网络io消耗

可以通过sar来分析网络的消耗状况,但是不能具体到每个线程所消耗的网络IO,只能对线程dump,查找产生了大量网络io的线程;

1.4内存消耗

结合top或pidstat,以及jvm的内存分析工具来分析内存消耗;要区分是jvm外的物理内存还是jvmheap区内存;如果是jvm外的物理内存要分析程序中DirectByteBuffer,如果是jvmheap可以通过jvisualvm来分析;

1.5资源消耗不多但仍然慢

主要原因是:锁竞争激烈,未充分使用硬件资源,数据量增长

第二步:性能调优

2.1jvm调优

主要包括各个代的大小、GC策略等;代大小的设置:避免新生代大小设置过小,或者过大;避免Survivor区过小或过大;合理设置新生代存活周期;GC策略根据吞吐量优先还是延迟优先进行设置策略;

2.2程序调优

1.CPU消耗严重解决

us过高主要是执行线程无任何挂起动作,可以进行Thread.sleep *** 作;sy过高主要是因为创建了过多的线程导致线程上下文切换;

2.文件IO消耗严重解决

造成文件IO消耗严重的原因主要是多个线程写大量的数据到同一个文件,导致文件很快变的很大,从而写入速度越来越慢,并造成各线程激烈竞争争抢文件锁,常用的调优方法:异步写文件,批量读写,限流,限制文件大小;

3.网络IO消耗严重解决

主要原因是同时发送或者接受的包太多,解决办法就是限流;

4.内存消耗严重解决

解决:释放不必要的引用,使用对象缓存池,采用合理的缓存失效策略,合理使用softReference和WeakReference;

2.3资源消耗不多但仍然慢

主要原因是:锁竞争激烈,未充分使用硬件资源

打开matlab2014a程序,在主工具栏找到应用程序一栏,打开optimization选项。

问题输入

在optimization程序中,首先根据不同的问题类型选择不同的模型,同时输入约束等。

选择优化程序运行的条件

在最中间的一栏中添加优化程序运行的条件,如优化截止的标准,画图的要求等等。

开始运算

点击start即可实现优化程序的运行,在图示的框中即可出现运行结果。

5

查看帮助文件

在程序的最右边,是一个帮助文件,如果你有什么疑问,可以直接在帮助文件中查找。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/11842616.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-19
下一篇 2023-05-19

发表评论

登录后才能评论

评论列表(0条)

保存