1. 程式人生 > >@NotNull, @NotEmpty和@NotBlank之間的區別是什麼?

@NotNull, @NotEmpty和@NotBlank之間的區別是什麼?

首先是簡要描述:

[java] view plain copy print?
  1. @NotNull://CharSequence, Collection, Map 和 Array 物件不能是 null, 但可以是空集(size = 0)。
  2. @NotEmpty://CharSequence, Collection, Map 和 Array 物件不能是 null 並且相關物件的 size 大於 0。
  3. @NotBlank://String 不是 null 且去除兩端空白字元後的長度(trimmed length)大於 0。
@NotNull://CharSequence, Collection, Map 和 Array 物件不能是 null, 但可以是空集(size = 0)。
@NotEmpty://CharSequence, Collection, Map 和 Array 物件不能是 null 並且相關物件的 size 大於 0。
@NotBlank://String 不是 null 且去除兩端空白字元後的長度(trimmed length)大於 0。

為了大家更好地理解,下面讓我們看下這些註解都是怎麼定義的(在version 4.1中)

1、@NotNull:

定義如下:

[java] view plain copy print?
  1. @Constraint(validatedBy = {NotNullValidator.class})  
@Constraint(validatedBy = {NotNullValidator.class})

這個類中有一個isValid方法是這麼定義的:
[java] view plain copy print?
  1. publicboolean isValid(Object object, ConstraintValidatorContext constraintValidatorContext) {  
  2.  return object != null;    
  3. }  
public boolean isValid(Object object, ConstraintValidatorContext constraintValidatorContext) {
 return object != null;  
}

物件不是null就行,其他的不保證。

2、@NotEmpty:

定義如下:

[java] view plain copy print?
  1. @NotNull
  2. @Size(min = 1)  
@NotNull  
@Size(min = 1)

也就是說,@NotEmpty除了@NotNull

之外還需要保證@Size(min=1),這也是一個註解,這裡規定最小長度等於1,也就是類似於集合非空。

3、@NotBlank:

[java] view plain copy print?
  1. @NotNull
  2. @Constraint(validatedBy = {NotBlankValidator.class})  
@NotNull  
@Constraint(validatedBy = {NotBlankValidator.class})

類似地,除了@NotNull之外,還有一個類的限定,這個類也有isValid方法:

[java] view plain copy print?
  1. if ( charSequence == null ) {  //curious 
  2.   returntrue;     
  3. }     
  4. return charSequence.toString().trim().length() > 0;    
if ( charSequence == null ) {  //curious 
  return true;   
}   
return charSequence.toString().trim().length() > 0;  
有意思的是,當一個string物件是null時方法返回true,但是當且僅當它的trimmed length等於零時返回false。即使當string是null時該方法返回true,但是由於@NotBlank還包含了@NotNull,所以@NotBlank要求string不為null。

給大家一些栗子幫助理解記憶:

  1. String name = null;
    @NotNull: false
    @NotEmpty: false
    @NotBlank: false

  2. String name = "";
    @NotNull: true
    @NotEmpty: false
    @NotBlank: false

  3. String name = " ";
    @NotNull: true
    @NotEmpty: true
    @NotBlank: false

  4. String name = "Great answer!";
    @NotNull: true
    @NotEmpty: true
    @NotBlank: true