本站消息

站长简介/公众号

  出租广告位,需要合作请联系站长


+关注
已关注

分类  

暂无分类

标签  

暂无标签

日期归档  

暂无数据

为什么要对 List 对象进行向上转型?Android / Java 语法

发布于2024-11-10 22:25     阅读(481)     评论(0)     点赞(19)     收藏(4)


最近,我一直在阅读许多 Android 项目的代码以获得更多理解。我看到的事情之一是 ArrayList 实例化的两种方式之间的差异。

请注意这里显示的两个示例。为什么有些人使用示例 1,为什么要这样做而不是示例 2,它们之间的主要区别是什么?

我理解 Java 中向上转换和向下转换的概念,但在这种特殊情况下没有任何优势。如果要创建一个 arrayList,为什么不从一开始就将其存储在 ArrayList 变量中?

我一直使用示例 2 创建新 ArrayList 的方法。我不明白使用示例 1 中显示的方法有什么好处

看起来更多的程序员使用示例 1 的方式

示例 1,使用向上转型到父变量

  List<String> list = new ArrayList<String>();

示例 2

  ArrayList<String> list = new ArrayList<String>();

解决方案


List是一个接口,因此不能实例化它..您必须使用它的具体实现来实例化,例如ArrayList

是否使用ListArrayList完全取决于其使用的上下文。

如果你想要一个ArrayList你应该用 ArrayList 来实例化它


向上转型通常是为了方法的可重用性而执行的,并且通常是自动完成的。

考虑使用这种方法对列表进行排序

public void sort(ArrayList lst);

您只能通过此方法对 ArrayList 进行排序。因此,如果您想对 LinkedList 对象进行排序,则必须创建另一个带有 LinkedList 参数的方法

现在考虑这种方法

public void sort(List lst);

现在,您可以通过传递实现 List 接口的类的对象来重用此方法。因此,您现在可以使用相同的方法对ArrayListLinkedListStack、进行排序。因此,Vector您现在可以重用相同的方法对实现 List 接口的不同类进行排序



所属网站分类: 技术文章 > 问答

作者:黑洞官方问答小能手

链接:http://www.javaheidong.com/blog/article/693737/19c24c486a22a451f73e/

来源:java黑洞网

任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任

19 0
收藏该文
已收藏

评论内容:(最多支持255个字符)