百科问答小站 logo
百科问答小站 font logo



为什么java中声明多用Map,List而不是具体实现类型? 第1页

  

user avatar   Ivony 网友的相关建议: 
      

一般来说接口定义的要求是宽进严出,也就是说参数类型更宽泛,更高层抽象,返回值更具体,更准确。


为什么需要这样?

如果一个函数只需要一个序列就能工作,那么没有必要弄个列表,这样这个函数可以更好的适配各种环境的调用,而不需要额外的适配代码。

如果函数能够产出一个列表,那么我就应当返回列表,别人只需要序列的时候,列表同样可以用。但别人需要列表的时候就不需要额外的适配了。


简单说就是宽进严出可以尽可能的避免各种适配代码。

当然任何原则都有其适用和不适用的场景。宽进严出是一个比较弱的原则,不能因为宽进严出来破坏语义。例如一个功能需要一个集合(不包含重复元素),那么参数就必须是集合而不应该是容器。一个功能的返回结果是只读的数据,就不应当返回可以读写的更具体的类型。



PS:

上文中的序列,可以理解为:Iterable<T>或者IEnumerable<T>,上文中的列表,可以理解为List<T>或者ILIst<T>




  

相关话题

  C# 事件效率如何? 
  为什么老板要教我们做互联网的程序员不要把工作和生活分开,这对于独立的程序员个体有什么好处? 
  实际开发中ref、out参数有多大作用? 
  为什么国内技术社区的影响力越来越弱呢? 
  为什么java中声明多用Map,List而不是具体实现类型? 
  国内Java面试总是问StringBuffer,StringBuilder区别是啥?档次为什么这么低? 
  代码全是调包的,怎么申请专利? 
  【C#】this 关键字限定本地类型的成员? 
  Markdown 标准化的阻碍在哪里? 
  如何看待不到40M的wps和1G多的office? 

前一个讨论
Nokia Lumia 920、925和928之间如何选择?
下一个讨论
如果双十一全国断网一天会发生什么?





© 2025-06-05 - tinynew.org. All Rights Reserved.
© 2025-06-05 - tinynew.org. 保留所有权利