java代码优化的小建议
2017-09-21 14:31
211 查看
final关键字
final关键字可以保证类和方法不被重写,另外final关键字修饰的方法还会建议JVM把此方法作为内联方法,注意此处只是建议,具体JVM会怎么优化还需要视情况而定。就算不用final修饰,JVM也同样会进行优化。
所以说想通过使用final修饰来提高性能的话,是不会带来很高的收益。对于一些小方法来说能加就加上final。
初始化大小,避免重建
ArrayList,HashMap,HashSet,StringBuilder等对象在创建的时候,有一个默认的大小,运行过程中如果数据大小不满足了,就会重新构建。建议初始化一个尽可能对的大小来避免重建。循环条件应避免方法调用
for(int i=0;i<list.size();i++){}
应改为
for(int i=0,len = list.size();i<len;i++){}
循环体内应尽量避免循环创建对象引用
for(int i=0;i<len;i++){ A a = new A(); }
应改为
A a = null; for(int i=0;i<len;i++){ a = new A(); }
循环方法
能用下标循环的首选下标循环,其次使用iterator循环,最后使用foreach循环。使用entrySet来遍历Map
entrySet循环map是效率最高的方法。Map<String,String> map = new HashMap<>(); for(int i = 0;i<1000000;i++){ map.put("a"+i, "bbbbbbbb"); } //foreach long now = System.currentTimeMillis(); map.forEach((t,u) ->{ }); System.out.println(System.currentTimeMillis() - now); //keySet now = System.currentTimeMillis(); Iterator<String> iter = map.keySet().iterator(); while(iter.hasNext()){ String key = iter.next(); String string = map.get(key); } System.out.println(System.currentTimeMillis() - now); //entrySet now = System.currentTimeMillis(); Set<Entry<String, String>> entrySet1 = map.entrySet(); for(Entry<String, String> entry : entrySet1){ String key = entry.getKey(); String value = entry.getValue(); } System.out.println(System.currentTimeMillis() - now);
输出结果如下:
98 47 34
相关文章推荐
- 关于Java代码优化的35条建议
- 关于Java代码优化的35条建议
- 44条Java代码优化建议
- java代码优化的小建议
- 44条Java代码优化建议
- 44条Java代码优化建议
- 编写高质量代码:改善Java程序的151个建议(第8章:多线程和并发___建议122~125)
- 编写高质量代码改善java程序的151个建议——[52-57]String !about String How to use them?
- Java代码性能优化总结
- Java 代码优化过程的实例介绍
- Java代码编写的30条建议
- 优化PHP代码的40条建议
- 编写高质量代码:改善Java程序的151个建议(第2章:基本类型___建议21~25)
- 编写高质量代码:改善Java程序的151个建议-学习笔记(9-12章)
- JAVA代码编写的30条建议
- Java程序性能优化:代码优化
- Java开发中程序和代码性能优化
- Java代码编写的30条建议
- 《编写高质量代码改善Java程序的151个建议》学习笔记 第6章 枚举和注解
- java代码优化浅析