zoukankan      html  css  js  c++  java
  • Java属性为什么不能是is开头的boolean

    Java属性为什么不能是is开头的boolean

    通常定义Java实体类时,对于boolean属性,阿里规约中明确要求不能使用is开头。

    至于为什么,我们稍后再讲。

    这里先讲一下前几天在工作中,项目遇到的一个问题。库表中某个字段存入了一个实体类的json字符串,在查询库表后,需要将json字符串转为实体类对象进行更改后再转为json字符串后返回给前端。

    在这当中就出现了一个问题,库表中存入的数据明明是isUpdate的字段,可是在返回到前端后的代码就是update
    这个问题,起初并没有想到是字段定义的问题,通过一步一步的debug,最后才发现是实体类中isUpdate字段的问题,在通过json解析后就转成了update返回给了前端。

    下面讲一下,为什么会出现isUpdate变成update的问题。


    首先,我们先定义一个Java实体类,包含一个is开头的属性,如isSuccess,再使用idea自动生成的get/set,看看是什么样子。

    public class IsEntity1 {
    
        private boolean isSuccess;   
        
        public boolean isSuccess() {
        	return isSuccess;        
        }  
        
        public void setSuccess(boolean success) {
        	isSuccess = success;        
        }   
        
    }
    

    然后再定义一个Java实体类,不是用is开头的属性,如success,再使用idea自动生成的get/set,看看是什么样子。

    public class IsEntity2 {
    
        private boolean success;
    
        public boolean isSuccess() {
            return success;
        }
    
        public void setSuccess(boolean success) {
            this.success = success;
        }
        
    }
    

    此时,会发现无论你是用is开头或者不用is开头定义属性,使用idea自动生成的get/set都是一个样子的,而且在setSuccess的时候,会将is省略掉。这里就是项目中遇到的问题所在。

    因为当类进行序列化时,有些框架的序列化会根据JavaBean的属性进行序列化,而部分框架是根据JavaBean的getter方法进行序列化,这就会导致在反序列化时与实体类的属性对应不上。

    比如说将IsEntity1转换为json字符串时,会根据实体类中的get方法进行序列化取isSuccess的值,而使用idea自动生成的get方法直接就是public boolean isSuccess()方法,在取值的时候会认定success是字段名,就会取成success,与原来定义的字段不同。

    如果非要使用is开头来定义字段,怎么才能保证json解析过程是正确的呢


    答案是自己写get方法,不用idea自动生成的get方法。

    如下:

    public boolean getIsSuccess() {
    	return isSuccess;
    }
    

    这样,再将实体类转为json字符串时,就会认定isSuccess是字段名。

    还有一种方法,就是使用JSONField注解

        @JSONField(name = "isSuccess")
        private boolean isSuccess;
    

    虽然这些方法都可以解决json解析过程丢失is的问题,但是为了避免出现这种问题,我们最好还是遵守规约,不使用is开头定义字段。

  • 相关阅读:
    C++实现单例模式
    进程间通信(IPC)介绍
    Python装饰器
    Python中import的使用
    Python中is和==的区别
    SK-Learn使用NMF(非负矩阵分解)和LDA(隐含狄利克雷分布)进行话题抽取
    Focal Loss for Dense Object Detection
    YOLOv3: An Incremental Improvement
    YOLO9000: Better, Faster, Stronger
    You Only Look Once: Unified, Real-Time Object Detection
  • 原文地址:https://www.cnblogs.com/Zzwena/p/13744846.html
Copyright © 2011-2022 走看看