1 尽可能使用局部变量
调用方法时传递的参数以及在调用中创建的临时变量都保存在栈中速度较快,其他变
量,如静态变量、实例变量等,都在堆中创建,速度较慢。另外,栈中创建的变量,随
着方法的运行结束,这些内容就没了,不需要额外的垃圾回收。
2
尽量减少对变量的重复计算
明确
一个概念,对方法的调用,即使方法中只有
一
句语句,也是有消耗的。所以例如下
面的操作:
for (int i =0; i < list.size(); i++)
{
...
}
建议替换为:
int length = list.size();
for (int i =0, i < length; i++)
{
...
}
这样,在
list.size()
很大的时候,就减少了很多的消耗。
3
尽量采用懒加载的策略,即在需要的时候才创建
String str ="aaa";
if (i == 1){
list.add(str);
}
//建议替换成
if (i == 1){
String str ="aaa";
list.add(str);
}
4
异常不应该用来控制程序流程
异常对性能不利。抛出异常首先要创建一
个新的对象,
Throwable
接口的构造函数调用
名为
fillInStackTrace()
的本地同步方 法,
fillInStackTrace()
方法检查堆栈,收集调用跟踪
信息。只要有异常被抛出,
Java
虚拟机就必须调整调用堆栈,因为在处理过程中创建了
一个新的对象。异常只能用于错误处理,不应该用来控制程序流程。
5
不要将数组声明为
public static final
因为这毫无意义,这样只是定义了引用为static final
,数组的内容还是可以随意改变的,
将数组声明为
public
更是一
个安全漏洞,这意味着这个数组可以被外部类所改变。
6
不要创建一
些不使用的对象,不要导入
一
些不使用的
类
,这毫无意义,如果代码中出现
"The value of the local variable i is not used"
"The import java.util is never used"
那么请删除这些无用的内容
7
程序运行过程中避免使用反射
反射是Java
提供给用户一
个很强大的功能,功能强大往往意味着效率不高。不建议在程序
运行过程中使用尤其是频繁使用反射机制,特别是
Method
的
invoke
方法。
如果确实有必要,一
种建议性的做法是将那些需要通过反射加载的类在项目启动的时候
通过反射实例化出一
个对象并放入内存。
8
使用数据库连接池和线程池
这两个池都是用于重用对象的,前者可以避免频繁地打开和关闭连接,后者可以避免频
繁地创建和销毁线程。
9
容器初始化时尽可能指定长度
容器初始化时尽可能指定长度,如:new ArrayList<>(10); new HashMap
<>(32);
避免容器长度不足时,扩容带来的性能损耗。
10
ArrayList
随机遍历快,
LinkedList
添加删除快
11
使用
Entry
遍历
Map
Map<String,String> map= new HashMap<>();
for (Map.Entry<String,String> entry : map.entrySet()) {
String key=entry.getKey();
String value=entry.getValue();
}
避免使用这种方式:
Map<String,String> map = new HashMap<>();
for (String key : map.keySet()) {
String value= map.get(key);
}
12
不要手动调用
System.
gc();
13
String
尽量少用正则表达式
正则表达式虽然功能强大,但是其效率较低,除非是有需要,否则尽可能少用。
replace() 不支持正则
replaceAll() 支持正则
如果仅仅是字符的替换建议使用replace()。
14 日志的输出要注意级别
15
对资源的
close()
建议分开操作
// 当前的日志级别是error
LOGGER.info("保存出错!"+ user);
try{
XXX.close();
YYY.close();
}
catch (Exception e){
...
}
// 建议改为
try{
XXX.close();}
catch (Exception e){
...
}
try{
YYY.close();
}
catch (Exception e){
...
}
版权声明:本文为xiaoxiaoli0_0原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。