回答: java代码调优笔记(一)
答复: java代码调优笔记(一)兄弟,你的总结很多我觉得有待考量,特别是在现代的jdk(1.4)已经做了很多优化,
答复: java代码调优笔记(一)
兄弟,你的总结很多我觉得有待考量,特别是在现代的jdk(>=1.4)已经做了很多优化,以下我的经验是在jdk1.6(以前1.5的也分析过)下的总结
public static final Boolean TRUE = new Boolean(true);public static final Boolean FALSE = new Boolean(false);
而valueOf(boolean b)的内部实现是:
return (b ? TRUE : FALSE);
因此用Boolean.valueOf(boolean b)代替new Boolean()既能节省空间,又能提高性能。
boolean b = false;
Boolean flag = b;
通过查看字节码,发现自动装箱时调用的正是Boolean.valueOf(boolean),即flag = Boolean.valueOf(b);
for (Object prop : props) {...}或者for (int i = 0, size = props.size(); i < size; i++) { Object prop = props.get(i);...}
这样对于变量prop我就知道,是为了处理集合元素需要,出了for没有用了。
反之:如果在代码开始就定义了prop如下代码
Object prop = null;for (int i = 0, size = props.size(); i < size; i++) { prop = props.get(i);...}...if (flag) prop = a result object;return prop还需要时刻关注是不是后面还使用了prop,
或者后面使用了prop时没有考虑,经过for后prop实际上不为null了。产生了误会。
所以为了代码的易懂可读,声明变量时尽量靠近使用变量的地方,有时候甚至可以使用{...}限定、突出其作用域。[/size]
for (int i = 0; i < 10000; ++i) { Object obj = new Object(); System.out.println("obj= " + obj);}
上面的做法会浪费较大的内存空间。正确的做法如下所示:
Object obj = null;for (int i = 0; i < 10000; ++i) { obj = new Object(); System.out.println("obj= "+ obj);}采用上面的第二种编写方式,仅在内存中保存一份对该对象的引用,而不像上面的第一种编写方式中代码会在内存中产生大量的对象引用,浪费大量的内存空间,而且增大了垃圾回收的负荷。因此在循环体中声明创建对象的编写方式应该尽量避免。
同上一条,这个并不是错误而且是一个很好的实践,代码可读性更好,性能影响基本没有。
cuishen 写道
(7). 如果if判断中多个条件用'||'或者'&&'连接,请将出现频率最高的条件放在表达式最前面。这个小技巧往往能有效的提高程序的性能,尤其是当if判断放在循环体里面时,效果更明显。
我认为应当把最可能让
条件成立(对于||)或者最可能让
条件失败(对于&&)的放在最前面。
兄弟你可以参考下。。。