4. Java集合知识测试

更新时间:2024-04-19 14:43:01 阅读量: 综合文库 文档下载

说明:文章内容仅供预览,部分内容可能不全。下载后的文档,内容与下面显示的完全一致。下载之前请确认下面内容是否您想要的,是否完整无缺。

集合部分测试题

考试宣言:

同学们, 考试考多少分不是我们的目的! 排在班级多少的名次也不是我们的初衷!

我们考试的目的是要通过考试中的题目,检查大家在这段时间的学习中,是否已经把需要掌握的知识掌握住了,如果哪道题目你不会做,又或者做错了, 那么不用怕, 考完试后, 导师讲解的时候你要注意听! 那时候学会了, 记住了, 也一样不影响你高薪就业!

本套题共40道不定项选择题,其中单选30道,多选10道。单选2分/题,多选4分/题。多选题不全对半分,全对满分。

1. 下列选项哪个正确(ac)

a) 对象数组是引用数据类型 b) 对象数组是基本数据类型

c) 对象数组存储的元素是引用数据类型 d) 对象数组存储的元素是基本数据类型

2. 下列选项关于集合和数组的区别说法正确的是( a)

a) 集合的长度是可变的,数组的长度是不可变的 b) 集合的长度是不可变的,数组的长度是可变的 c) 集合和数组都能存储基本数据类型和存储引用类型

d) 集合只能存储基本数据类型,数组既能存储基本类型也能存储引用类型

3. Collection获取长度的方法是哪个(b )

a) length() b) size() c) add()

d) iterator()

4. 将集合转换成数组的方法是哪个(c )

a) toCharArray() b) getBytes() c) toArray() d) size()

5. iterator()方法的功能是什么(c )

a) 获取集合对象 b) 获取集合的长度 c) 获取迭代器对象 d) 获取集合中元素

6. 并发修改异常的解决方案哪些正确( abc )

a) 用普通for循环和get()可以解决并发修改异常 b) 用列表迭代器可以解决并发修改异常 c) 用迭代器可以解决并发修改异常 d) 没有方法能解决并发修改异常

7. 下列关于Vector说法正确的是(ad )

a) Vector是JDK1.0开始出现的 b) Vector是一个抽象类 c) Vector是一个接口

d) Vector后来被ArrayList取代了,但是某些老项目中还在延续使用

8. 数组数据结构的特点是什么(ac )

a) 增删慢 b) 查询慢 c) 查询快 d) 增删快

9. 下列描述ArrayList集合特点正确的是( bd)

a) 底层是链表数据结构 b) 底层是数组数据结构 c) 是线程安全的 d) 是线程不安全的

10. 列描述LinkedList集合特点正确的是( d )

a) 底层是数组数据结构

b) 底层是二叉树结构 c) 是线程安全的 d) 是线程不安全的

11. 下列关于ArrayList的contains(Object obj)方法的理解正确的是(ab )

a) 底层会调用obj的equals方法

b) 如果这个方法的返回值是true,就说明集合中含有obj这个元素 c) 如果这个方法的返回值是false,就说明集合中没有obj这个元素 d) 这是一个静态方法

12. 在下列代码中,关于it.next()方法的作用理解正确的是( b)

ArrayList list = new ArrayList(); list.add(new Person(\张三\list.add(new Person(\张三\list.add(new Person(\李四\list.remove(new Person(\张三\

a) 代码移除了所有的张三

b) 如果Person类实现了equals方法,那么就会移除所有张三 c) 如果Person类实现了equals方法,那么就会移除一个张三 d) 可能不会移除任何对象

13. 下列代码list中的元素存储的顺序是(b )

LinkedList list = new LinkedList(); list.addFirst(\list.addFirst(\list.addFirst(\list.addFirst(\list.addLast(\

System.out.println(list);

a) abcde b) edcba c) acdbe d) dcbae

14. Java中,关于队列的的说法正确的是( a )

a) 队列的特点是先进先出 b) 队列的特点是后进先出 c) 队列的特点是先进后出

d) 队列的特点是后进后出

15. 下列有关泛型的代码中,说法正确的是( a ) ArrayList list = new ArrayList();

a) list集合里面只能存放Person对象 b) list集合里面能存放字符串

c) list集合里面能存放Person的子类对象 d) list集合里面可以存放Object类型的对象

16. 下列关于泛型说法不正确的是( b )

a) 泛型的出现可以把运行时出现的问题提前放到编译时期就发现 b) 泛型的出现可以把编译时出现的问题放到运行之后就发现 c) 泛型可以避免强制类型转换 d) 泛型是一种安全机制

17. 观察如下代码,下列说法不正确的是( a ) public class Tool { }

a) b) c) d)

格式错误,因为Q不知道是什么

可以这样创建对象:new Tool(); 去掉Tool上的Q,可以用String来代替 可以这样创建对象:new Tool();

18. 下面泛型方法中,说法正确的是( B ) private void show2(T t) { }

a) b) c) d)

在调用show2方法的时候,才会确定T的类型是什么 此方法会报错,因为格式不对

定义格式错误,此方法中应该改为 定义格式错误,参数列表应该改为(T,Q t)

19. 下列增强for循环的代码中,有关说法正确的是( d ) for(int x : arr){ System.out.println(x);

}

a) arr必须是一个int数组

b) arr 可以是字符串数组 c) arr 必须是一个集合

d) arr可以是数组也可以是集合对象 自动拆箱

20. 要遍历元素对象,下面横线处填写的代码应为( c ) ArrayList list = new ArrayList<>(); list.add(\ list.add(\ list.add(\

for( ____________ ){ System.out.println(x);

}

a) int x : list b) Object x : list c) String x : list

d) int x=0;x

21. 能删除下面集合中所有的字符串“b”的代码的是( b ArrayList list = new ArrayList<>();

list.add(\ list.add(\ list.add(\ list.add(\ list.add(\

a)

for(int i = 0; i < list.size(); i++) { if(\ list.remove(i);

} }

b)

for(String str : list){ if(“b”.equals(str)){

list.remove(str); } } c)

for(int i = 0; i < list.size(); i++) {

if(\ list.remove(i--);

}

)

}

d) for(String s : list){ list.remove(“b”);

}

22. 关于可变参数的说法正确的是( aBC )

a) 可变参数的格式为【数据类型 … 变量名】 b) 可变参数实际上这个参数是一个数组 c) 直接打印可变参数,得到的是一个地址值 d) 可变参数就是可以传递任意多个对象

23. 使用HashSet存储对象,如何保证唯一( c )

a) 重写equals方法

b) 让要存储的类实现Compartor,重写compare方法 c) 根据成员变量重写HashCode方法和equals方法 d) 重写contains方法

24. HashSet在存储元素的时候,以下说法错误的是( d )

a) 可以定义泛型 b) 可以存储任意内容

c) 存储的元素有一定的顺序

d) 存储的元素会按照一定的规则去重复

25. HashSet中常见的方法有( d )

a) b) c) d)

add,remove.get,size

get(int pos) insert()

add,remove,size

26. 根据下面的代码,选出空白处应填写的代码表示存储1-20的随机数( a )

HashSet hs = new HashSet(); Random r = new Random(); while(hs.size() < 10) {

补全此处代码 hs.add(num);

}

for (Integer integer : hs) { System.out.println(integer);

} a) b) c) d)

int num = r.nextInt(20) + 1; int num = r.nextInt(20) ; Math.random();

Math.random(20)+1;

27. 根据下面的代码,选出空白处应填写的代码( a )

Scanner sc = new Scanner(System.in); System.out.println(\请输入一行字符串:\String line = 补全此处代码; char[] arr = line.toCharArray(); HashSet hs = new HashSet<>();

for(char c : arr) { hs.add(c); for (Character ch : hs) { System.out.println(ch); }

a) String line = sc.nextLine(); b) String line = sc.newLine(); c) String line = sc.readLine(); d) String line = sc.getString();

}

28. TreeSet底层实际的操作对象是(a )

a) TreeMap b) HashMap

c) LinkedHashMap d) LinkedTreeMap

29. 下面的方法,目的是在TreeSet中对元素进行排序,但是要保留重复元素,补全下面的

代码( a )

public static void sort(List list) {

TreeSet ts = new TreeSet<>(new Comparator() {

@Override

public int compare(String s1, String s2) { int num = s1.compareTo(s2); 补全此处代码 }

a) b) c) d)

});

ts.addAll(list); list.clear(); list.addAll(ts);

return num == 0 ? 1 : num; return num == 1 ? 0 : num; return num == 1; return num;

30. 比较器必须实现以下哪个接口( a )

a) Comparator b) Comparable c) Collection d) Map

31. 关于Map集合的描述,以下说法错误的是(c)

a) Map集合是双列集合

b) Map集合的数据结构只针对键有效 c) Map集合的键可以是重复的 d) 以上都不对

32. 往Map集合中添加元素,可以通过以下那个方法(a)

a) b) c) d)

put(K key,V value)

add(K key,V value) keySet(K key,V value) containsKey(Object key)

33. Map集合中,获取所有键的集合,是以下哪个方法(c)

a) b) c) d)

remove()

entrySet() keySet() keys()

34. Itetator迭代器中的hasNext()方法的作用是(a)

a) 判断集合中是否还有下一个元素 b) 判断集合中是否还有上一个元素 c) 获取集合中的下一个元素 d) 获取集合中的上一个元素

35. Map集合中,获取所有键值对的集合是那个方法(a)

a) entrySet() b) values() c) keySet() d) keyValues()

36. 应用程序的main方法中有以下语句(请参看API文档)

Hashtable hashtable=new Hashtable(); hashtable.put(\hashtable.put(\hashtable.put(\

System.out.println(hashtable.get(\ + hashtable.get(\

+ hashtable.get(\ 则输出的结果是 (d ) a) 编译失败 b) bbb c) ccc

d) cccbbbaaa

37. TreeMap通过自然排序保证元素的唯一性,必须重写哪个方法(b)

a) equals() b) compareTo() c) compare() d) toString()

38. TreeMap通过比较器接口,保证元素唯一性,必须重写哪个方法(c)

a) equals() b) compareTo() c) compare() d) toString()

39. 使用TreeSet的无参构造创建集合对象存储元素时,该元素必须(b)

a) 有main方法

b) 必须实现Comparable接口 c) 有get和set方法

d) 必须实现Serializable接口

40. Collections工具类中的binarySearch()方法描述正确的是(b)

a) binarySearch()方法只能操作Set集合

b) binarySearch()方法可以操作所有的集合 c) binarySearch()方法只能操作Map集合 d) binarySearch()方法只能操作List集合

本文来源:https://www.bwwdw.com/article/hq2p.html

Top