一般来说接口定义的要求是宽进严出,也就是说参数类型更宽泛,更高层抽象,返回值更具体,更准确。
为什么需要这样?
如果一个函数只需要一个序列就能工作,那么没有必要弄个列表,这样这个函数可以更好的适配各种环境的调用,而不需要额外的适配代码。
如果函数能够产出一个列表,那么我就应当返回列表,别人只需要序列的时候,列表同样可以用。但别人需要列表的时候就不需要额外的适配了。
简单说就是宽进严出可以尽可能的避免各种适配代码。
当然任何原则都有其适用和不适用的场景。宽进严出是一个比较弱的原则,不能因为宽进严出来破坏语义。例如一个功能需要一个集合(不包含重复元素),那么参数就必须是集合而不应该是容器。一个功能的返回结果是只读的数据,就不应当返回可以读写的更具体的类型。
PS:
上文中的序列,可以理解为:Iterable<T>或者IEnumerable<T>,上文中的列表,可以理解为List<T>或者ILIst<T>