Java程序员面试题----数组、集合框架

1. 如何理解数组在Java中作为一个类?

Java的数组本质上是一个类,该类还保存了数据类型的信息,通过成员变量的形式来保存数据,并且通过[]符号,使用下标来访问这些数据。在处理基本类型数据时(如int[] arr = new int[]{1,2,3,4,5}),数组保存的是变量的值,如果程序员未提供初始值,数组会把这些变量初始化为0,而处理引用类型时(如String[] arr1 = new String[3]),数组保存事务是数据的引用,如果程序员为提供初始值,数组会把这些变量的值初始化为null。

2. new Object[5]语句是否创建了5个对象?

答案为否,题目的语句其实是创建了一个数组实例,长度为5,数组中的每个元素的值为null,并没有创建5个Object对象。如果需要创建5个Object对象,则需要为每个数组元素分别指定。

3. 如何拷贝数组中的数据?

使用System.arraycopy()方法,或者创建一个新的数组是咧,然后要拷贝的数据一一填进去,不能用=赋值运算符。

4.  二维数组长度是否固定?

长度不固定,Java数组的长度是可以动态变化的,程序员可以任意扩展数组的维度,每一个维度的元素个数都可以是不尽相同的。如二维数组:

int[][] arr = new int[3][];

arr[0] = new int[]{1};

arr[1] = new int[]{2.3};

arr[2] = new int[]{4,5,6};

5.  什么是集合?

集合是用来也只能存储其他对象的对象,代表了一种底层结构,用于扩展数组的功能。集合框架由一系列的接口和实现类组成,基本包括:列表(List)、集合(Set)、映射(Map)、它们大多具有可迭代性和可比较性。

6.  迭代器是什么?

迭代器,提供一种访问一个集合对象中各个元素的途径,同时又不需要暴露该对象的内部细节。Java通过提供Iterable和Iterator两个接口来实现集合类的可迭代性。迭代器主要的用法就是:首先用HasNext()作为循环条件,再用next()方法得到每一个元素,最后在进行相关的操作。

7.  比较器是什么?

比较器是把集合或数组的元素强行按照指定的方法进行排序的对象,它是实现了Comparator接口类的实例。如果一个集合元素的类型是可比较的(是实现了Comparable接口),要么它具有了默认的排序方法,比较器则是强行改变它默认的比较方式来进行排序。或者有的集合元素不可比较(没有实现Comparable接口)则可用比较器来实现动态的排序。

8.  Vector与ArrayList的区别?

Vector线程是安全的,因为它操作元素的方法是同步方法,而ArrayList则不是,开发过程中应该根据需要进行选择,如果需要保证线程安全则需要使用Vector,而不必要的时候无需使用Vector,因为ArrayList效率会高一些。

9.  HashMap和HashTable的区别?

HashTable的方法是同步的,HashMap不能同步;

HashTable不允许null值(key和vaule都不可以),HashMap允许null值(key和vaule都可以);

HashTable有一个contains()方法,功能和HashMap中containsVaule()功能一样;

HashTable使用Enumeration遍历,HashMap使用Iterator遍历;

HashTable中hash数组默认大小为11,增加的方式是old*2+1,HashMap中hash数组默认大小为16,增加的方式一定是2的指数;

哈希值的使用不同,HashTable直接使用对象的hashCode,而HashMap会重新计算hash值;

10. 集合使用泛型带来了什么好处?

集合使用泛型 后,可以达到元素类型明确的目的,避免了手动类型转换的过程,同时,也让开发者更加明确容器保存的是什么类型的数据。

11. 如何把集合对象的元素进行排序?

对于没有排序功能的集合来说,都可以使用java.util.Collections.sort()方法进行排序,它除了集合对象以外,还需要提供一个比较器。如果列表中的元素全部都是相同类型的,并且这个类实现了Comparable接口,可以简单地调用Collections.sort()。如果这个类没有实现Comparator,就可以传递一个Comparator实例作为sort()的第二个参数进行排序,另外,如果不想使用默认的分类顺序进行排序,同样可以传递一个Comparator实例作为参数进行排序。

12. 符合什么条件的数据集合可以使用foreach循环?

数组或者实现了Iterable接口的类实例,都是可以使用foreach循环的,Java集合框架中的集合类大多数都符合第二条。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值