当前位置: 移动技术网 > IT编程>开发语言>Java > Java编程代码性能优化

Java编程代码性能优化

2019年07月22日  | 移动技术网IT编程  | 我要评论
一、咱们之所以这么干的目的:     1.效率(最重要)   2.可读性,便于后期维护。(同样很重要) 二、代码优化的要求:   1.减小代码的体积。   2.提

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

  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

  //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()。

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

如您对本文有疑问或者有任何想说的,请 点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网