Java代码优化

 

1)StringBuffer表示了可变的、可写的字符串。
有三个构造方法 :
StringBuffer (); //默认分配16个字符的空间
StringBuffer (int size); //分配size个字符的空间
StringBuffer (String str); //分配16个字符+str.length()个字符空间
通过StringBuffer的构造函数来设定它的初始化容量,这样可以明显地提升性能。
这里提到的构造函数是StringBuffer(int length),length参数表示当前的StringBuffer能保持的字符数量。你也可以使用ensureCapacity(int minimumcapacity)方法在StringBuffer对象创建之后设置它的容量。首先我们看看StringBuffer的缺省行为,然后再找出一条更好的提升性能的途径。

 

StringBuffer在内部维护一个字符数组,当你使用缺省的构造函数来创建StringBuffer对象的时候,因为没有设置初始化字符长度,StringBuffer的容量被初始化为16个字符,也就是说缺省容量就是16个字符。当StringBuffer达到最大容量的时候,它会将自身容量增加到当前的2倍再加2,也就是(2*旧值+2)。如果你使用缺省值,初始化之后接着往里面追加字符,在你追加到第16个字符的时候它会将容量增加到34(2*16+2),当追加到34个字符的时候就会将容量增加到70(2*34+2)。无论何事只要StringBuffer到达它的最大容量它就不得不创建一个新的字符数组然后重新将旧字符和新字符都拷贝一遍。这也太昂贵了点。所以总是给StringBuffer设置一个合理的初始化容量值是错不了的,这样会带来立竿见影的性能增益。StringBuffer初始化过程的调整的作用由此可见一斑。所以,使用一个合适的容量值来初始化StringBuffer永远都是一个最佳的建议。

 

2)当复制大量数据时,使用System.arraycopy()命令。
int[] src={1,3,5,6,7,8};
int[] dest = new int[6];
System.arraycopy(Object src,int srcPos,Object dest,int destPos,int length);
src:源数组; srcPos:源数组要复制的起始位置;
dest:目的数组; destPos:目的数组放置的起始位置; 
length:复制的长度.

注意:src and dest都必须是同类型或者可以进行转换类型的数组。

 

3)用移位操作替代乘法操作可以极大地提高性能。

 

4)array(数组) 和 ArryList的使用

array([]):最高效;但是其容量固定且无法动态改变;
ArrayList:容量可动态增长;但牺牲效率;
基于效率和类型检验,应尽可能使用array,无法确定数组大小时才使用ArrayList!
ArrayList是Array的复杂版本
ArrayList内部封装了一个Object类型的数组,从一般的意义来说,它和数组没有本质的差别,甚至于ArrayList的许多方法,如Index、IndexOf、Contains、Sort等都是在内部数组的基础上直接调用Array的对应方法。
ArrayList存入对象时,抛弃类型信息,所有对象屏蔽为Object,编译时不检查类型,但是运行时会报错。
注:jdk5中加入了对泛型的支持,已经可以在使用ArrayList时进行类型检查。

从这一点上看来,ArrayList与数组的区别主要就是由于动态增容的效率问题了。

 

5)尽量使用HashMap 和ArrayList ,除非必要,否则不推荐使用HashTable和Vector ,后者由于使用同步机制,而导致了性能的开销。

 

6)尽量避免使用split,除非是必须的,否则应该避免使用split,split由于支持正则表达式,所以效率比较低,如果是频繁的几十,几百万的调用将会耗费大量资源,如果确实需要频繁的调用split,可以考虑使用apache的 StringUtils.split(string,char),频繁split的可以缓存结果。

 

7)尽量使用继承,继承的方法越多,你要写的代码量也就越少。

 

8)把公用的代码提取出来

 

9)日期类型的对象会占用很大的空间,如果你要存储大量的日期对象,可以考虑把它存储为long型,然后在使用的时候转换为Date类型。

 

10)类名,方法名和变量名尽量使用简短的名字,可以考虑使用Hashjava, Jobe, Obfuscate and Jshrink等工具自动完成这个工作。

 

 

11)map用该方法遍历效率最高:

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

 

12)当比较俩个List集合时,使用这种方法效率较高:

List diff = new ArrayList();  
List maxList = list1;  
List minList = list2;  
if(list2.size()>list1.size()){  
          maxList = list2;  
          minList = list1;  
      }  
for (String string : maxList) {  
         map.put(string, 1);  
      }  
for (String string : minList) {  
         Integer cc = map.get(string);  
    if(cc!=null){  
         map.put(string, ++cc);  
         continue;  
        }  
         map.put(string, 1);  
    }  
for(Map.Entry entry:map.entrySet())  
         {  
if(entry.getValue()==1)  
          {  
           diff.add(entry.getKey());  
          }  
 }  

 

13)多重循环要遵循外小内大原则,提取循环内无关的计算表达式、多次利用的变量。捕获异常放在循环外面。

 

14)Java之Map遍历方式性能分析:ketSet 与 entrySet

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值