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



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

  

user avatar   Ivony 网友的相关建议: 
      

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


为什么需要这样?

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

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


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

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



PS:

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




  

相关话题

  有什么行为习惯昭示着你是个编程大佬? 
  怎样评价《数码宝贝》第一部中的泉光子郎的编程水平? 
  为什么总有一些人推荐计算机学生把重点放在高数和线代? 
  把 string 当 enum 用,有性能损失吗? 
  如何抽象评判现有语言优劣,继而设计一款别具优雅的计算机语言 X ? 
  GitHub 上有什么好的或者有趣的 Shell 项目? 
  不适合编程的人是怎样的? 
  仅仅从好玩程度考虑,做编译器或操作系统哪个更有趣味? 
  golang,告警业务,每个告警源都有不同的分发频率,告警源可能新增or删除,该如何设计? 
  假设开发某款软件1个程序员10天可以做好,那么找10个同等水平程序员一起做1天能否做好? 

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





© 2025-04-24 - tinynew.org. All Rights Reserved.
© 2025-04-24 - tinynew.org. 保留所有权利