写代码容易犯的一些小错误和踩的一些坑

1、关于基本数据类型与包装数据类型的使用标准如下:
  • 所有的POJO类属性必须使用包装数据类型。
  • RPC方法的返回值和参数必须使用包装数据类型。
  • 所有的局部变量推荐使用基本数据类型。
2、单个方法的总行数不超过80行。
3、避免通过一个类的对象引用访问此类的静态变量或静态方法,无谓增加编译器解析成本,直接用类名来访问即可。
4、POJO类中的任何布尔类型的变量,都不要加is,否则部分框架解析会引起序列化错误
错误案例:      
    public class DemoDO{
        Boolean isSuccess;
        Boolean isDelete;
    }

正确写法:
    public class DemoDO{
        Boolean success;
        Boolean delete;
    }
5、循环体内,字符串的联接方式,使用StringBuilder的append方法进行扩展。

说明:反编译出的字节码文件显示每次循环都会new出一个StringBuilder对象,然后进行append操作,最后通过toString方法返回String对象,造成内存资源浪费。

错误案例:
    String result;
    for (String string : tagNameList) {
        result = result + string;
    }

        
            
正确写法:
    StringBuilder stringBuilder = new StringBuilder();
    for (String string : tagNameList) {
        stringBuilder.append(string);
    }
    String result = stringBuilder.toString();
6、集合初始化时,指定集合初始值大小。

说明:HashMap使用如下构造方法进行初始化,如果暂时无法确定集合大小,那么指定默认值(16)即可。

错误案例:
	Map<String, String> map = new HashMap<String, String>();
    
       
正确写法:
	Map<String, String> map = new HashMap<String, String>(16);
7、所有的包装类对象之间值的比较,全部使用equals方法比较。

说明:对于Integer var=?在-128至127之间的赋值,Integer对象是在IntegerCache.cache产生,会复用已有对象,这个区间内的Integer值可以直接使用==进行判断,但是这个区间之外的所有数据,都会在堆上产生,并不会复用已有对象,这是一个大坑,推荐使用equals方法进行判断。

	Integer a = 235;
    Integer b = 235;
    if (a.equals(b)) {
        // code
    }
8、Object的equals方法容易抛空指针异常,应使用常量或确定有值的对象来调用equals。
错误案例:   
	public void f(String str){
        String inner = "hi";
        if (str.equals(inner)) {
            System.out.println("hello world");
        }
    }
       
正确写法:
	public void f(String str){
        String inner = "hi";
        if (inner.equals(str)) {
            System.out.println("hello world");
        }
    }
9、抽象类命名使用Abstract或Base开头
  abstract class BaseControllerDemo{
    }

    abstract class AbstractActionDemo{
    }

10、除常用方法(如getXxx/isXxx)等外,不要在条件判断中执行复杂的语句,将复杂逻辑判断的结果赋值给一个有意义的布尔变量,以提高可读性。

说明:很多if语句内的逻辑相当复杂,阅读者需要分析条件表达式的最终结果,才能明确什么样的条件执行什么样的语句,那么,如果阅读者分析逻辑表达式错误呢?

错误案例:
    if ((file.open(fileName, "w") != null) && (...) || (...)) {
        // ...
    }
			
        
            
正确写法:
    boolean existed = (file.open(fileName, "w") != null) && (...) || (...);
    if (existed) {
        //...
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值