设为首页收藏本站language→→ 语言切换

鸿鹄论坛

 找回密码
 论坛注册

QQ登录

先注册再绑定QQ

查看: 924|回复: 0
收起左侧

10个经典Java集合面试题——南京Java培训整理

[复制链接]
发表于 2016-10-20 11:15:32 | 显示全部楼层 |阅读模式
  Java集合框架为Java编程语言的基础,也是Java面试中很重要的一个知识点。这里,南京万和Java培训列出了一些关于Java集合的重要问题和答案。

  1.队列和栈是什么,列出它们的区别?

  栈和队列两者都被用来预存储数据。java.util.Queue是一个接口,它的实现类在Java并发包中。队列允许先进先出(FIFO)检索元素,但并非总是这样。Deque接口允许从两端检索元素。

  栈与队列很相似,但它允许对元素进行后进先出(LIFO)进行检索。

  Stack是一个扩展自Vector的类,而Queue是一个接口。

  2.Collections类是什么?

  Java.util.Collections是一个工具类仅包含静态方法,它们操作或返回集合。它包含操作集合的多态算法,返回一个由指定集合支持的新集合和其它一些内容。这个类包含集合框架算法的方法,比如折半搜索、排序、混编和逆序等。

  3.Comparable和Comparator接口是什么?

  如果我们想使用Array或Collection的排序方法时,需要在自定义类里实现Java提供Comparable接口。

  Comparable接口有compareTo(T OBJ)方法,它被排序方法所使用。我们应该重写这个方法,如果“this”对象比传递的对象参数更小、相等或更大时,它返回一个负整数、0或正整数。

  但是,在大多数实际情况下,我们想根据不同参数进行排序。

  比如,作为一个CEO,我想对雇员基于薪资进行排序,一个HR想基于年龄对他们进行排序。这就是我们需要使用Comparator接口的情景,因为Comparable.compareTo(Object o)方法实现只能基于一个字段进行排序,我们不能根据对象排序的需要选择字段。

  Comparator接口的compare(Object o1, Object o2)方法的实现需要传递两个对象参数,若第一个参数比第二个小,返回负整数;若第一个等于第二个,返回0;若第一个比第二个大,返回正整数。更多内容,请咨询南京万和Java培训

  4.Comparable和Comparator接口有何区别?

  Comparable和Comparator接口被用来对对象集合或者数组进行排序。Comparable接口被用来提供对象的自然排序,我们可以使用它来提供基于单个逻辑的排序。

  Comparator接口被用来提供不同的排序算法,我们可以选择需要使用的Comparator来对给定的对象集合进行排序。

  5.我们如何对一组对象进行排序?

  如果我们需要对一个对象数组进行排序,我们可以使用Arrays.sort()方法。如果我们需要排序一个对象列表,我们可以使用Collection.sort()方法。

  两个类都有用于自然排序(使用Comparable)或基于标准的排序(使用Comparator)的重载方法sort()。Collections内部使用数组排序方法,所有它们两者都有相同的性能,只是Collections需要花时间将列表转换为数组。

  6.当一个集合被作为参数传递给一个函数时,如何才可以确保函数不能修改它?

  在作为参数传递之前,我们可以使用Collections.unmodifiableCollection(Collection c)方法创建一个只读集合,这将确保改变集合的任何操作都会抛出UnsupportedOperationException。

  7.我们如何从给定集合那里创建一个synchronized的集合?

  我们可以使用Collections.synchronizedCollection(Collection c)根据指定集合来获取一个synchronized(线程安全的)集合。

  8.集合框架里实现的通用算法有哪些?

  Java集合框架提供常用的算法实现,比如排序和搜索。Collections类包含这些方法实现。大部分算法是操作List的,但一部分对所有类型的集合都是可用的。部分算法有排序、搜索、混编、最大最小值。更多内容,请咨询南京万和Java培训

  9.大写的O是什么?举几个例子?

  大写的O描述的是,就数据结构中的一系列元素而言,一个算法的性能。

  Collection类就是实际的数据结构,我们通常基于时间、内存和性能,使用大写的O来选择集合实现。比如:

  例子1:ArrayList的get(index i)是一个常量时间操作,它不依赖list中元素的数量。所以它的性能是O(1)。

  例子2:一个对于数组或列表的线性搜索的性能是O(n),因为我们需要遍历所有的元素来查找需要的元素。

  10.与Java集合框架相关的有哪些最好的实践?

  (1)根据需要选择正确的集合类型。比如,如果指定了大小,我们会选用Array而非ArrayList。如果我们想根据插入顺序遍历一个Map,我们需要使用TreeMap。如果我们不想重复,我们应该使用Set。

  (2)一些集合类允许指定初始容量,所以如果我们能够估计到存储元素的数量,我们可以使用它,就避免了重新哈希或大小调整。

  (3)基于接口编程,而非基于实现编程,它允许我们后来轻易地改变实现。

  (4)总是使用类型安全的泛型,避免在运行时出现ClassCastException。

  (5)使用JDK提供的不可变类作为Map的key,可以避免自己实现hashCode()和equals()。

  (6)尽可能使用Collections工具类,或者获取只读、同步或空的集合,而非编写自己的实现。它将会提供代码重用性,它有着更好的稳定性和可维护性。

  以上是南京万和Java培训老师做的一些简单总结,希望能帮助到大家,希望大家都能进一家自己如意的公司,找到自己事业上的家。

您需要登录后才可以回帖 登录 | 论坛注册

本版积分规则

QQ|Archiver|手机版|小黑屋|sitemap|鸿鹄论坛 ( 京ICP备14027439号 )  

GMT+8, 2024-4-27 18:23 , Processed in 0.097381 second(s), 10 queries , Redis On.  

  Powered by Discuz!

  © 2001-2024 HH010.COM

快速回复 返回顶部 返回列表