java性能提升

1 代码方面:

1)已知的高效代码,将值定位在某个区间时,可以用&运算代替%运算。

2)需要一个死循环的时候使用for(;;)代替while.do,在字节码时会节省指令。

3)合理的打印关键日志,减少JSON的String和Object的转换。

4)使用Lambda表达式代替匿名内部接口/类,在虚拟机中有优化。

5)在线程安全的情况下使用非线程安全类,更高效,stringbuilder代替stringbuffer。

6)在多线程并发的情况下,使用concurrenthashmap和放弃HashTable

7)在多线程并发的List情况下copyonwritearraylist(读更优秀,写的时候有额外的内存开销),Collections.synchronizedList(Lists.newArrayList())(写更优秀),减少HashTable和同步List的使用。详情链接:https://blog.csdn.net/xiangcaoyihan/article/details/78228962

8)进行输入和输出的时候要及时关闭流。

9)并行取数时,使用countdownlatch

2 jvm方面考虑

1)大对象在使用完成以后可以显示的设置为null,有助于垃圾回收。

2)减少FullGC为目标,增加eden区,减少old区。

3)在jvm启动参数配置上考虑,初始分配空间,以及堆外内存需要显示(System.gc())回收方面。

4)如果在类中的1个方法中使用了成员,要考虑是否可以将成员变量变为局部变量。

原文地址:https://www.cnblogs.com/zzq-include/p/12899403.html