sonar代码检查

常见问题1

使用字符索引 : String.indexOf(char) is faster than String.indexOf(String).

代码举例: if(splitArray[i].indexOf("}")!=-1)

修改建议: if(splitArray[i].indexOf('}')!=-1)

常见问题2

在进行比较时,字符串文本应该放在左边 : Move the "0" string literal on the left side of this string comparison.

代码举例:  if(enNameArray[1].equals("0")){ 

            enName = enNameArray[2];

            }

修改建议: if("0".equals(enNameArray[1])){ .......

常见问题3

应该使用Collection.isEmpty()判断空集合 : Use isEmpty() to check whether the collection is empty or not.

代码举例:  if(names.size() == 0){ 

            .........

            }

修改建议: if(names.isEmpty()){ .......

常见问题4

返回之前不用的本地变量 : Consider simply returning the value vs storing it in local variable 'flightLineQueryForm'.

代码举例:

 

修改建议: 

 

常见问题5

整型实例 : Avoid instantiating Integer objects. Call Integer.valueOf() instead.代码举例: properties.put("CCSID", new Integer(req.getQueueCCSID()));  

修改建议: properties.put("CCSID", Integer.valueOf(req.getQueueCCSID()));

修改分析:JDK1.5后增加了Integer.valueOf. 因此1.5前不能用.从源代码可以知道,ValueOf-128127256个值做了缓存(IntegerCache),如果int值的范围是:-128127,在ValueOf(int)时,会直接返回IntegerCache的缓存。

常见问题6

低效的StringBuffer : Avoid concatenating nonliterals in a StringBuffer constructor or append().

代码举例: retStr.append("PNR"+locatorID); 

修改建议: retStr.append("PNR");

           retStr.append(locatorID);

常见问题7

精确初始化 : Variable 'bEnvInited' explicitly initialized to 'false' (default value for its type).

代码举例: private static boolean bEnvInited = false;

修改建议: private static boolean bEnvInited;

常见问题8

精确初始化 : 应该合并可折叠的"if"语句 : Merge this if statement with the enclosing one.

代码举例: 

 

修改建议:

 

常见问题9

方法名需要遵守命名规则 : Rename this method name to match the regular expression '^[a-z][a-zA-Z0-9]*$'.

代码举例: private boolean ISpasstype(String type) {......

修改建议: private boolean iSpasstype(String type) {......

常见问题10

避免在循环体中声明创建对象.

代码举例: 

 

修改建议: 

 

常见问题11

常量名应该遵守命名规则 : Rename this constant name to match the regular expression '^[A-Z][A-Z0-9]*(_[A-Z0-9]+)*$'.

代码举例: protected static final String HomophoneRule="Homophone";

修改建议: protected static final String HOMOPHONE_RULE="Homophone";

常见问题12

安全 - 直接保存数组 : The user-supplied array 'destCityArray' is stored directly.代码举例: 

 

修改建议:

 

常见问题13

类变量不应该有公开访问权限 : Make this class field a static final constant or non-public and provide accessors if needed.

代码举例: 

public static Timestamp foreverLong = SimpleDate.MaxDate().getTimestamp(); 

修改建议: 

private static Timestamp foreverLong = SimpleDate.MaxDate().getTimestamp(); 

总结

本文介绍的主要是自己在用SONAAR修改JAVA代码中经常遇到的代码质量问题,自己总结了了一些修改方法,在此给大家分享一下。由于写作水平和能力有限,文中如有不妥的地方或者有更好的建议,欢迎联系我。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Sonar是一款流行的代码检查工具,旨在帮助开发人员提高代码质量和可维护性。它能够通过静态分析代码,发现潜在的缺陷、漏洞和不良实践。 Sonar具有以下核心功能: 1. 代码质量评估:Sonar可以评估代码的质量,包括复杂性、重复代码、安全漏洞等。它通过规则引擎检查代码,然后生成详尽的问题报告,开发人员可以根据报告修复问题。 2. 技术债务管理:Sonar可以帮助团队管理技术债务。技术债务是指在项目中出现的需要修复的问题。Sonar能够识别技术债务,并为其设置优先级,使开发人员知道哪些问题最需要解决。 3. 持续集成:Sonar支持与持续集成工具的集成,例如Jenkins。当开发人员提交代码时,Sonar可以自动执行代码分析,并在构建过程中提供有关代码质量的反馈。 4. 存档和趋势:Sonar可以记录和存档每次代码分析的结果,并生成趋势报告。这可以帮助开发人员了解代码质量的改进和退步,并追踪项目在时间轴上的变化。 5. 编码规则:Sonar内置了许多常见的编码规范和最佳实践,开发人员可以根据自己的需求自定义规则。这有助于团队在整个项目中保持一致的编码风格和标准。 Sonar是一个功能强大且灵活的工具,它可以帮助开发团队确保代码质量,并提供及时的反馈。通过使用Sonar,开发人员能够更快地发现和解决潜在的问题,提高代码的可维护性和可靠性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值