• 【java】代码优化点


    1.对数据库数据的计数统计,尽量在数据库查询时候就使用count()进行统计,避免返回List到项目中统计List大小

    2.对于数据库中表中字段数据过长,例如存储的是text类型而不是verchar类型的,可以创建新的实体去接收mybatis的查询结果,返回部分要用到的数据即可,不用将一整条数据全部返回给项目

    3.对于List的分割操作,可以避免使用subList()方法进行分割,因为subList()会创建新的List集合去接收分割结果,内存开销大。可以使用remove仅操作原List完成分割。

    参考地址:【https://www.cnblogs.com/sxdcgaq8080/p/9376947.html

    4.在保证代码命名可以有效看懂的情况下,尽量减少源代码的码量,从细微的地方减少编译后class文件的大小。

    5.而减少编译后class文件大小的最有效的方法,就是1》代码逻辑清晰,程序流程设计完美,是最有效减少码量的方法  2》尽量抽离重复代码,提高代码的高可用行,也是减少码量的不二法门

    6.mybatis的IN查询,如果list过大,应该进行List的切割,IN查询分批次查询,避免拼接sql语句过长

    7.mybatis sql查询时,尽量少使用

      where 1=1

      <if> and ......</if>

    因为1=1写在where第一位,则数据表中如果有索引的话,那根据最左原则,表上创建的Index就失效了。

     优化方案:https://www.cnblogs.com/sxdcgaq8080/p/9412167.html

    8.java中使用StringBuffer进行append操作时,需要注意:

     方式1:

     for (String s : split) {
         // public static final String LINE_FEED_CHAR = System.getProperty("line.separator");
                            
            StringBuffer content = new StringBuffer();
            content.append(s + SecurityCodeBusinessOrderServiceImpl.LINE_FEED_CHAR);
     }

    效率要比下面这种效率高:

      方式2:

    content.append(s).append(SecurityCodeBusinessOrderServiceImpl.LINE_FEED_CHAR);

    原因是因为: 

    SecurityCodeBusinessOrderServiceImpl.LINE_FEED_CHAR

    是常量,所以直接进行拼接可以直接从常量池中获取到。

    而方式2要append()两次,则方法栈就会压入两次,如果循环操作1000,则append()入方法栈就有2000次

    9.项目上线之前,所有的System.out.println()都要替换为log4j或logger,否则轻则影响性能,重则服务挂掉

    开发代码中要使用log.info代替System.out.println()。

    因为system.out.print()的

    1》加锁机制,导致同步输入,影响服务性能【性能对比:https://www.cnblogs.com/sxdcgaq8080/p/9646802.html

    2》输出信息的分类、格式化及永久保存

    这些劣势决定!!

     10.

  • 相关阅读:
    定时备份脚本
    NFS+inotify实时同步
    pxe+kickstart自动化安装
    LVS负载均衡DR模式
    Rsync文件同步服务
    NFS文件共享服务
    MySQL-5.5.49安装、多实例、主从复制
    PHP-5.3.27源码安装及nginx-fastcgi配置
    一文解读5G (转)
    一文解读VR/AR/MR (转)
  • 原文地址:https://www.cnblogs.com/sxdcgaq8080/p/9405117.html
Copyright © 2020-2023  润新知