zoukankan      html  css  js  c++  java
  • Java编码优化

    Java编码优化

    1.尽可能使用局部变量
    调用方法时传递的参数以及在调用中创建的临时变量都保存在栈中速度较快,其他变 量,如静态变量、实例变量等,都在堆中创建,速度较慢。另外,栈中创建的变量,随 着方法的运行结束,这些内容就没了,不需要额外的垃圾回收。
    2.尽量减少对变量的重复计算
    明确一个概念,对方法的调用,即使方法中只有一句语句,也是有消耗的,比如:

    for (int i = 0; i < list.size(); i++) {...}
    //应该替换成:
    int length = list.size(); 
    for (int i = 0, i < length; i++) {...}
    

    在list.size()很大的时候,就减少了很多的消耗

    3.尽量采用懒加载的策略,即在需要的时候才创建

    String str = "aaa";
    if (i == 1){
        list.add(str);
    }
    //建议替换成
    if (i == 1){
        String str = "aaa";
        list.add(str);
    }
    

    4.异常不应该用来控制程序流程 异常对性能不利。
    抛出异常首先要创建一个新的对象,Throwable接口的构造函数调用 名为fillInStackTrace()的本地同步方 法,fillInStackTrace()方法检查堆栈,收集调用跟踪 信息。只要有异常被抛出,Java虚拟机就必须调整调用堆栈,因为在处理过程中创建 了 一个新的对象。异常只能用于错误处理,不应该用来控制程序流程。

    5.不要将数组声明为public static final
    因为这毫无意义,这样只是定义了引用为static final,数组的内容还是可以随意改变的, 将数组声明为public更是一个安全漏洞,这意味着这个数组可以被外部类所改变。

    6.不要创建一些不使用的对象,不要导入一些不使用的类
    如果代码中出现"The value of the local variable i is not used"、"The import java.util is never used",那么请删除这些无用的内容

    7.程序运行过程中避免使用反射
    反射是Java提供给用户一个很强大的功能,功能强大往往意味着效率不高。不建议在程序 运行过程中使用尤其是频繁使用反射机制,特别是 Method的invoke方法。 如果确实有必要,一种建议性的做法是将那些需要通过反射加载的类在项目启动的时候 通过反射实例化出一个对象并放入内存。

    8.使用数据库连接池和线程池
    这两个池都是用于重用对象的,前者可以避免频繁地打开和关闭连接,后者可以避免频 繁地创建和销毁线程。

    9.容器初始化时尽可能指定长度
    容器初始化时尽可能指定长度,如:new ArrayList<>(10); new HashMap<>(32); 避免容 器长度不足时,扩容带来的性能损耗

    10.使用Entry遍历Map

    Map map = new HashMap<>(); 
    for (Map.Entry entry : map.entrySet()){ 
        String key = entry.getKey(); 
        String value = entry.getValue();
    }
    
    //避免使用这种方式,因为这样就会做两次遍历,先遍历出key再单独去遍历出value,而Entry则只会做一次,它会一次性将键值对都遍历出来
    Map map = new HashMap<>(); 
    for (String key : map.keySet()) { 
        String value = map.get(key);
    }
    

    11.不要手动调用System.gc();
    因为手动调用GC可能会影响到虚拟机对gc的判断,可以设置参数来禁用调用System.gc()

    12.String尽量少用正则表达式
    正则表达式虽然功能强大,但是其效率较低,除非是有需要,否则尽可能少用。
    replace() 不支持正则
    replaceAll() 支持正则
    如果仅仅是字符的替换建议使用replace()。

    13.日志的输出要注意级别

    // 当前的日志级别是error ,但要执行info,这样里面的内容执行就没有意义,做了无用功
    LOGGER.info("保存出错!" + user);
    

    14.对资源的close()建议分开操作

    try{
        XXX.close();
        YYY.close();
    }
    catch (Exception e){
        ...
    }
    // 建议改为,因为写在一起,如果其中一个出错可能导致直接进入catch代码块而另一个资源没有被释放
    try{
            XXX.close();
    }
    catch (Exception e){
        ...
    }
    try{
        YYY.close();
    }
    catch (Exception e){
        ...
    }
    

    本博客为Swagger-Ranger的笔记分享,文章会持续更新
    文中源码地址: https://github.com/Swagger-Ranger
    欢迎交流指正,如有侵权请联系作者确认删除: liufei32@outlook.com

  • 相关阅读:
    servlet 项目 ,,启动没问题,,但是,一请求也面就报错误。。。。求解决。。。。。。。。。。。。。各种百度,都没解决了啊。。。。。急急急急急急急急急急急急急急急急急急
    js 表单不为空,数字长度验证
    cordova 安卓项目打包 release安装包
    Vue-cli构建项目, 组件中js代码引入图片路径问题
    Vue-cli 构建项目 的`.vue`组件中, scss中添加背景图路径问题
    解决 Cordova命令突然无法使用问题.
    VS Code 自用插件备份
    Cordova环境搭建
    前端渲染与后端渲染方式大体对比
    JavaScript-获取当前元素的相关元素或节点--方法总结
  • 原文地址:https://www.cnblogs.com/Swagger-Ranger/p/10707282.html
Copyright © 2011-2022 走看看