【笔记54】返回空的数组或者集合,不要返回null

private final List<Cheese> cheesesInStock = ...;
public Cheese[] getCheeses(){
   if (cheesesInStock.size == 0)
       return null;
}

把没有奶酪可买的情况当做一种特例,这是不合常理的。这样做会要求客户端必须有额外的代买来处理null的返回值。例如

Cheese[] cheeses  = shop.getCheeses();
if(cheeses != null && Arrays.asList(cheeses).contains(Cheese.STILTON)){
    System.out.println("Jolly good,just the thing.") ;
}

而不是下面这段代码:

if( Arrays.asList(cheeses).contains(Cheese.STILTON)){
    System.out.println("Jolly good,just the thing.") ;
}

这样做很容易出错,因为编写客户端程序的程序员可能会忘记写这种专门的代码来处理null返回值。这样的错误也许几年都不会被注意到,因为这样的方法通常返回一个或者多个对象。

有时候会有人认为:null返回值比零长度数组更好,因为它避免了分配数组所需要的开销。
这个观点站不住脚,首先这个级别担心性能是不明智的,除非分析表明这个方法就是造成性能的根本原因;其次对于不返回任何元素的调用,每次都返回同一个零长度数组是可能的,因为零长度数组是不可变的,而不可变对象有可能被自由共享。实际上,当使用标准做法把一些元素从一个集合转存到一个类型化的数组中时,它正式这样做的:

private final List<Cheese> cheeseInStock = …;
   private static final Cheese[] EMPTY_CHEESE_ARRAY =new Cheese[0];
   public Cheese[] getCheeses(){
       return cheeseInStock.toArray(EMPTY_CHEESE_ARRAY);  
 }

习惯用法中,零长度数组常量被传递给toArray方法,以指明所期望的返回类型。正常情况下,toArray方法分配了返回的数组,如果集合是空的,它将使用零长度输入数组。

集合值方法可以做成需要返回空集合时返回同一个不可变的空集合。Collections.emptySet(),
Collections.emptyList(),Collections.emptyMap()方法正是所需要的。

 private final List<Cheese> cheeseInStock = …;
   public List<Cheese> getCheesesList(){
       if (cheeseInStock.isEmpty())
           rerurnCollections.emptyList();
       else
          return  new ArrayList(cheeseInStock);
  }

总之,返回类型为数组或集合的方法没有理由返回null,而是返回一个零长度的数组或者集合。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值