java声明问题:List<String> list=new ArrayList<String>();为甚麼要声明为List 而不是ArrayList<String>?
最好用例子说明,谢谢。
wode5130:
不知道你是否说错了,List<String> list=new ArrayList<String>()是向上转型而不是向下转型。
你的回答的重点,我了解了就是"有时候我们不一定想用 ArrayList ,而要用 LinkedList ,这时候直接 list = new LinkedList<String>();就可以了",但是我想问"要用 LinkedList 的时候就要重新声明一个变量,"有甚麼大问题呢?只不过是多一行code而已。
List是集合最大的父类,它包含了ArrayList。
如果直接声明为ArrayList<String> list=new ArrayList<String>()这个也没有问题。
而声明成:List<String> list=new ArrayList<String>();这样的形式使得list这个对象可以有多种的存在形式,比如要用链表存数据的话直接用LinkedList,使用ArrayList或者Vector直接通过list去=就可以了,这样让list这个对象活起来了,“有甚麼大问题呢?只不过是多一行code而已。”
其实不止多一行代码,很多需求只能用一个list,内存有限,或者线程同步,不能有更多的集合对象,使得List总的接口来管理对象。
扩展资料:
在编程语言中List 是标准类库中的一个类,可以简单视之为双向链表,以线性列的方式管理物件集合。list 的特色是在集合的任何位置增加或删除元素都很快,但是不支持随机存取。
list 是类库提供的众多容器(container)之一,除此之外还有vector、set、map、…等等。list 以模板方式实现(即泛型),可以处理任意型别的变量。
包括使用者自定义的资料型态例如:它可以是一个放置整数(int)型态的 list、也可以是放置字串(char 或 string)型态的 list、或者放置使用者自定类别(user-defined class)的 list。
有序的 collection(也称为序列)。此接口的用户可以对列表中每个元素的插入位置进行精确地控制。用户可以根据元素的整数索引(在列表中的位置)访问元素,并搜索列表中的元素。
与vector的区别
参考list是双向循环链表,,每一个元素都知道前面一个元素和后面一个元素。在STL中,list和vector一样,是两个常被使用的容器。和vector不一样的是,list不支持对元素的任意存取。
list中提供的成员函数与vector类似,不过list提供对表首元素的操作push_front、pop_front,这是vector不具备的。
和vector另一点不同的是,list的迭代器不会存在失效的情况,他不像vector会保留备份空间,在超过容量额度时重新全部分配内存,导致迭代器失效;list没有备份空间的概念,出入一个元素就申请一个元素的空间,所以它的迭代器不会失效。
与 set 不同,列表通常允许重复的元素。更确切地讲,列表通常允许满足 e1.equals(e2) 的元素对 e1 和 e2,并且如果列表本身允许 null 元素的话,通常它们允许多个 null 元素。难免有人希望通过在用户尝试插入重复元素时抛出运行时异常的方法来禁止重复的列表,但我们希望这种用法越少越好。
List 接口在 iterator、add、remove、equals 和 hashCode 方法的协定上加了一些其他约定,超过了 Collection 接口中指定的约定。为方便起见,这里也包括了其他继承方法的声明。
List 接口提供了 4 种对列表元素进行定位(索引)访问方法。列表(像 Java 数组一样)是基于 0 的。注意,这些操作可能在和某些实现(例如 LinkedList 类)的索引值成比例的时间内执行。因此,如果调用者不知道实现,那么在列表元素上迭代通常优于用索引遍历列表。
List 接口提供了特殊的迭代器,称为 ListIterator,除了允许 Iterator 接口提供的正常操作外,该迭代器还允许元素插入和替换,以及双向访问。还提供了一个方法来获取从列表中指定位置开始的列表迭代器。
List 接口提供了两种搜索指定对象的方法。从性能的观点来看,应该小心使用这些方法。在很多实现中,它们将执行高开销的线性搜索。
List 接口提供了两种在列表的任意位置高效插入和移除多个元素的方法。
参考资料来源:百度百科--java接口
参考资料来源:百度百科--list
...ArrayList<String>();为甚麼要声明为List 而不是ArrayList<String>...
如果直接声明为ArrayList<String> list=new ArrayList<String>()这个也没有问题。而声明成:List<String> list=new ArrayList<String>();这样的形式使得list这个对象可以有多种的存在形式,比如要用链表存数据的话直接用LinkedList,使用ArrayList或者Vector直接通过list去=就可以了,这样让list这个对象活起来...
JAVA中的一个小问题
List<String> ls = new ArrayList<String>(); \/\/1 List<Object> lo = ls; \/\/2第1行当然合法,但是这个问题的狡猾之处在于第2行。 这产生一个问题: 一个String的List是一个Object的List么?大多数人的直觉是回答:“当然!”。好,在看下面的几行: lo.add(new Object()); \/\/ 3 String s = ls.get(...
java中 List mylist =new ArrayList 怎么理解
List是java.util包中的一个定义集合对象的接口,ArrayList是实现List接口的实现类。单就这个语法而言,如使用List mylist =new ArrayList();定义对象时,比使用ArrayList mylist =new ArrayList();易于扩展;如当你在使用中发现ArrayList类型的对象不能满足你的使用要求时,你可以改成其他的实现List接口的...
List<Article> articles = new ArrayList<Article>();
list 一个接口,可以理解为线性表吧,ArrayList是实现它的一个类,<> 泛型的概念,意思是在一创建的list中,只能放你指定的对象
List 声明为final,那么这个list 可以用执行add()方法吗? 在线等哈...
list,StringBuffer 可以,但是不能修改引用,也就不能再次赋值 其它的不行.因为 list,StringBuffer 中实际存储数据的元素不是final的
java怎么用一行代码初始化ArrayList
Aires", "Córdoba", "La Plata")); 有这样做的更好的方法吗?感谢阅读 ! 解决方法 1: 其实,可能要初始化的"最佳"方式,ArrayList 是你写的方法,因为它不需要创建一个新的 List 以任何方式:ArrayList<String> list = new ArrayList<String>(); list.add("A"); list.add("B");...
java如何得到一个方法返回的list
List list = new ArrayList>();for (int i = 1; i <= 10; i++) { list.add(i);} return list;} ```在此方法中,返回类型声明为 `List`,意味着该方法必须返回一个 `List` 类型的对象。如果不返回任何值,至少要返回 `null`,因为Java的方法如果返回类型不是 `void`,就必须返回一...
java高级开发工程师面试题(java高级开发工程师面试题目及答案)
应聘JAVA工程师,面试官常问一些什么问题?1、java面试中经常被问到的问题有如下:简述string对象,StringBuffer、StringBuilder区分。多态的原理。简要描述面向对象编程的思想。反射的原理。java.util包的UML结构图。Vector和ArrayList、LinkedList区别。2、首先都是问工作经历,上一家公司的工作情况(应届生会问...
java高级开发工程师面试问题(java高级开发笔试题)
java面试中经常被问到的问题有如下:简述string对象,StringBuffer、StringBuilder区分。多态的原理。简要描述面向对象编程的思想。反射的原理。java.util包的UML结构图。Vector和ArrayList、LinkedList区别。“Java是解释执行”,这句话正确吗?考点分析:对于这类笼统的问题,你需要尽量表现出自己的思维深入并...
Java开发最常犯的10个错误,打死都不要犯!
错误一:Array转成ArrayList的误解 尽管将数组转换为ArrayList看起来简单直接,但其实背后隐藏了一些陷阱。通过Arrays.asList()方法得到的ArrayList,内部结构是固定的,不支持动态添加或删除元素。正确的做法是先使用ArrayList的构造函数接收一个集合参数,或者直接new一个ArrayList并使用add()方法。错误二:检查...