一、咱们之所以这么干的目的:  

  1.效率(最重要)

  2.可读性,便于后期维护。(同样很重要)

二、代码优化的要求:

  1.减小代码的体积。

  2.提高代码的运行效率。

三、常用的代码的优化:

  1、尽量重用对象

    特别是String对象的重用。最常用的就是字符串的拼接:

        当遇到频繁擦拼接String时。记住一定用StringBuilder/StringBuffer

    例如:

     ArrayList<String> list;
//省去list初始化。
StringBuilder builder = new StringBuilder(); for (String s : list) {
builder.append(s);
}
String result = builder.toString();

    原因:Java虚拟机不仅要花时间生成对象,而且还要花时间处理和回收对象,生成过多对象必定会给程序性能带来影响。

  2. 尽可能使用局部变量 :

    局部变量在栈中创建,创建速度快,用完即自动消失,不需要额外的垃圾回收。

    而静态变量、实例变量等在堆中创建,创建速度慢,同时还依赖Java垃圾回收机制处理。

  

  3. 及时关闭流 :

    Java程序开发中,在对I/O,数据库操作结束后,一定要记住关闭流。

    原因:未关闭流会对系统造成很大的开销,甚至会对数据造成严重的后果。

  4. 使用懒加载

    懒加载 : 当要用的时候才创建该对象。

    例如:

     String prefix = "gebi";

     if ("laowang".equals(name)) {
list.add(prefix + name);
}

  替换为:

     if("laowang".equals(name)) {
String prefix = "gebi";
list.add(prefix + name);
}

  5.避免在循环中使用try...catch,在循环外层使用try...catch
            
  

  6.try...catch不宜太大。

    不要将无用代码,即不会抛出异常的代码统统放入try...catch块中,减小try...catch代码块的大小。

    保证代码的可读性,易维护性,健壮性。

  

  7.循环内尽量避免创建对象的引用。

    尤其是循环量大的时候。

     while (i<1000) {
Object object = new Object();
}

建议修改为:

     Object object = null;

     while (i<1000) {
object = new Object();

    每次new Object()的时候,Object对象引用指向Object对象。

    当循环次数多的时候,如第一种,JVM会创建1000个对象的引用,而第二种内存中只有一份Object对象引用。这样就大大节省了内存空间了。

  8.不要随意使用static变量。

    当对象被声明为static的变量所引用时,此时,Java垃圾回收器不会清理这个对象所占用的堆内存。

    静态变量所占用的堆内存直到该变量所在类所在程序结束才被释放。 即静态变量生命周期=类生命周期。

  9.不要创建一些不使用的对象,不要导入一些不使用的类。

  10.使用带缓冲的I/O流:

    带缓冲的I/O流可以极大提高I/O效率。BufferedWriter, BufferedReader, BufferedInputStream, BufferedOutputStream。

  11.包装类数据转换为字符串使用: toString  

    Integer i = 1;

     包装类数据转换为字符串方法速度排名 :

       i.toString > String.valueOf(i) > "" + i

  

  12.Map遍历效率 : entrySet > keySet

     //entrySet()
for (Entry<String, String> entry : map.entrySet()) {
String key = entry.getKey();
String value = entry.getValue();
System.out.println(key + " : " + value);
} //上下对比 //keySet()
for (String key : map.keySet()) {
String value = map.get(key);
System.out.println(key + " : " + value);
}

  

  13.关于Iterator与forEach()的集合遍历舍取。

    算法导论上说:算法是为了提高空间效率和时间效率。但往往时间和空间不能并存。

    时间效率:Iterator > forEach()

    代码可读性 : forEach() > Iterator
                

 1     //Iterator
Set<Entry<String, String>> entrySet = map.entrySet();
Iterator<Entry<String, String>> iter = entrySet.iterator(); while (iter.hasNext()) {
Entry<String, String> entry = iter.next();
String key = entry.getKey();
String value = entry.getValue();
System.out.println(key + " : " + value);
}

    对比:

     //forEach()
for (Entry<String, String> entry : map.entrySet()) {
String key = entry.getKey();
String value = entry.getValue();
System.out.println(key + " : " + value);
}

个人认为:当处理大数据时推荐使用Iterator遍历集合。

         但处理小数据的话,为了可读性和后期维护还是使用forEach()。

         两者结合使用,都应该掌握。

Java----代码优化篇的更多相关文章

  1. Java代码优化的30个小技巧

    前言 我之前写过两篇关于优化相关的问题:<聊聊sql优化的15个小技巧>和<聊聊接口性能优化的11个小技巧>,发表之后,在全网受到广大网友的好评.阅读量和点赞率都很高,说明了这 ...

  2. Java提高篇——对象克隆(复制)

    假如说你想复制一个简单变量.很简单: int apples = 5; int pears = apples; 不仅仅是int类型,其它七种原始数据类型(boolean,char,byte,short, ...

  3. Java提高篇(三三)-----Map总结

    在前面LZ详细介绍了HashMap.HashTable.TreeMap的实现方法,从数据结构.实现原理.源码分析三个方面进行阐述,对这个三个类应该有了比较清晰的了解,下面LZ就Map做一个简单的总结. ...

  4. Java提高篇(三二)-----List总结

    前面LZ已经充分介绍了有关于List接口的大部分知识,如ArrayList.LinkedList.Vector.Stack,通过这几个知识点可以对List接口有了比较深的了解了.只有通过归纳总结的知识 ...

  5. Java提高篇(三一)-----Stack

    在Java中Stack类表示后进先出(LIFO)的对象堆栈.栈是一种非常常见的数据结构,它采用典型的先进后出的操作方式完成的.每一个栈都包含一个栈顶,每次出栈是将栈顶的数据取出,如下: Stack通过 ...

  6. java提高篇(三十)-----Iterator

    迭代对于我们搞Java的来说绝对不陌生.我们常常使用JDK提供的迭代接口进行Java集合的迭代. Iterator iterator = list.iterator(); while(iterator ...

  7. java提高篇(二九)-----Vector

    在java提高篇(二一)-–ArrayList.java提高篇(二二)-LinkedList,详细讲解了ArrayList.linkedList的原理和实现过程,对于List接口这里还介绍一个它的实现 ...

  8. Java提高篇(二八)------TreeSet

    与HashSet是基于HashMap实现一样,TreeSet同样是基于TreeMap实现的.在<Java提高篇(二七)-----TreeMap>中LZ详细讲解了TreeMap实现机制,如果 ...

  9. Java提高篇(二七)-----TreeMap

    TreeMap的实现是红黑树算法的实现,所以要了解TreeMap就必须对红黑树有一定的了解,其实这篇博文的名字叫做:根据红黑树的算法来分析TreeMap的实现,但是为了与Java提高篇系列博文保持一致 ...

  10. Java提高篇(二六)-----hashCode

          在前面三篇博文中LZ讲解了(HashMap.HashSet.HashTable),在其中LZ不断地讲解他们的put和get方法,在这两个方法中计算key的hashCode应该是最重要也是最 ...

随机推荐

  1. StrictMode对SharedPreferences的检查出来的IO操作

    在使用StrictMode时,发现会爆出 StrictMode policy violation;~duration=1949 ms: android.os.StrictMode$StrictMode ...

  2. ORA-04031 With Leak in "OBJ STAT MEMO" Allocations Seen in V$SGASTAT on 10.2.0.5 (文档 ID 1350050.1)

    APPLIES TO: Oracle Server - Enterprise Edition - Version: 10.2.0.5<max_ver> and later   [Relea ...

  3. 安装LINUX X86-64的10201出现链接ins_ctx.mk错误

    在安装linux X86-64的Oracle10201时,在链接过程中出现了这个错误. 详细错误信息为: Error in invoking target ‘install’ of makefile  ...

  4. (旧)子数涵数·PS——替换颜色

    一,老规矩,下载素材(老样子,还是美美的少女) 二.打开PS,并打开素材. 三.复制一个图层,快捷键Ctrl+J(好习惯) 四.使用"替换颜色"命令,弹出对话框. 五.选择人物衣服 ...

  5. Orchard官方文档翻译(四) 让Orchard在WebMatrix下工作

    原文地址:http://docs.orchardproject.net/Documentation/Working-with-Orchard-in-WebMatrix 想要查看文档目录请用力点击这里 ...

  6. 计数排序(Count Sort )与插入排序(Insert Sort)

    计数排序法:计数数组适用于当前数组密集的情况.例如(2,3,5,4,2,3,3,2,5,4) 方法:先找出最大值最小值,之后统计每个数出现的次数,根据次数从小到大往数组里添加 计数排序法是一种不需要比 ...

  7. unknown software exception

    打开cmd 输入下面代码,回车,等跑完即解决for %1 in (%windir%\system32\*.dll) do regsvr32.exe /s %1

  8. MySql 日期函数

    在 MySql 中经常会用到日期,关于常用的日期函数,做了以下的总结: 1 . now() 作用; 获取当前的日期 除此之外,获取当前日期的函数还有: current_timestamp(); cur ...

  9. 学习练习 session练习

    <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding= ...

  10. ASPxCallback控件

    ASPxCallback控件简单来的来说是一个数据回调控件,即不刷新事个页面来展现数据,主要是通过注册客户端事件与服务器端的事件来相互通信完成任务. 如何使用ASPXCallback: 向页面添加Ca ...