【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.

原文地址:https://www.cnblogs.com/sxdcgaq8080/p/9405117.html