java集合类面试题_Java集合类相关面试题

java集合类面试题_Java集合类相关面试题1、Collection和Collections的差别java.util.Collection是一个集合接口,Collection接口在Java类库中有非常多详细的实现。比如List、Setjava.util.Collections是针对集合类的一个帮助类,它提供了一系列的静态方法实现对各种集合的搜索、排序、线程安全化等操作。2、ArrayList与Vector的差别这两个类都实现了List接…

大家好,又见面了,我是你们的朋友全栈君。

1、Collection和Collections的差别

java.util.Collection 是一个集合接口,Collection接口在Java类库中有非常多详细的实现。比如List、Set

java.util.Collections 是针对集合类的一个帮助类,它提供了一系列的静态方法实现对各种集合的搜索、排序、线程安全化等操作。

2、ArrayList与Vector的差别

这两个类都实现了List接口(List接口继承自Collection接口)。它们都是有序集合。它们内部的元素都是能够反复的,都能够依据序号取出当中的某一元素。

它们两个的差别在于:

(1)、线程安全的问题:Vector是早期Java就有的,是同意多线程操作的。是线程安全的;而ArrayList是在Java2中才出现,它是线程不安全的,仅仅能使用单线程

操作。 因为Vector支持多线程操作,所以在性能上就比不上ArrayList了。

相同的HashTable相比于HashMap也是支持多线程的操作而导致性能不如HashMap。

(2)、数据增长的问题

ArrayList和Vector都有一个初始的容量大小,当存储进去它们里面的元素个数超出容量的时候。就须要添加ArrayList和Vector的存储空间,每次添加存储空间

的时候不是仅仅添加一个存储单元。是添加多个存储单元。

Vector默认添加原来的一倍,ArrayList默认添加原来的0.5倍。

Vector能够由我们自己来设置增长的大小,ArrayList没有提供相关的方法。

3、LinkedList与ArrayList有什么差别

两者都实现的是List接口。不同之处在于:

(1)、ArrayList是基于动态数组实现的,LinkedList是基于链表的数据结构。

(2)、get訪问List内部随意元素时。ArrayList的性能要比LinkedList性能好。LinkedList中的get方法是要依照顺序从列表的一端開始检查,直到还有一端

(3)、对于新增和删除操作LinkedList要强于ArrayList。由于ArrayList要移动数据

4、去掉Vector中的一个反复元素

import java.util.HashSet;

import java.util.Iterator;

import java.util.Vector;

public class VectorDemo {

public static void main(String[] args) {

Vector veList=new Vector();

veList.add(“aa”);

veList.add(“bb”);

veList.add(“aa”);

veList.add(“bb”);

veList.add(“cc”);

//去掉Vector中的反复元素方法一:

veList=getNewVector(veList);

//迭代结果

System.out.println(“*************************第一种方式************************”);

for(int i=0;i

System.out.println(veList.get(i));

}

//去掉Vector中的反复元素方法二:

Vector veList1=getNewVector1(veList);

System.out.println(“*************************另外一种方式************************”);

for(int i=0;i

System.out.println(veList1.get(i));

}

}

private static Vector getNewVector(Vector veList) {

Vector newVector=new Vector();

for(int i=0;i

String str=(String) veList.get(i);

if(!newVector.contains(str)){

newVector.add(str);

}

}

return newVector;

}

private static Vector getNewVector1(Vector veList) {

Vector newVector=new Vector();

HashSet set=new HashSet(veList);

Iterator it =set.iterator();

while (it.hasNext()) {

String str=(String) it.next();

newVector.add(str);

}

return newVector;

}

}

5、HashMap与HashTable的差别

两者都实现了Map接口。主要差别在于:

(1)、HashTable是早期Java就有的,支持多线程操作。是线程安全的。HashMap是Java2才出现的。是HashTable的轻量级实现,仅支持单线程操作。线程不安

全的。

(2)、HashMap同意空的key和value  HashTable不同意

6、List与Map的差别

List是存储单列数据的集合,Map是存储key和value这样双列数据的集合,List中存储的数据是有顺序的,而且同意反复。

Map其中存储的数据是没有顺序的,它

存储的key是不能反复的,value是能够反复的。

List继承Collection接口,Map不是。Map没有父类

7、List、Map、Set三个接口。存取元素时各有什么特点

首先List和Set都是单列元素的集合。它们有一个共同的父接口Collection。

List内的元素讲究有序性。内部元素可反复。可是Set恰恰相反。它讲究的是无序性,元素不可反复。Set的add方法有一个boolean的返回值,每当add一个新元

素的时候都会调用equals方法进行逐一比較,当新元素与全部的已存在元素的都不反复的时候add成功返回true。否则返回false。

Map与List和Set不同,它是双列存储的(键和值一一相应)。它在存储元素调用的是put方法,每次存储时,要存储一份key和value。不能存储反复的key,这个

反复的规则也是利用equals进行比較。取数据的时候则能够依据key获取value。另外还是以获得全部key的集合和全部value的集合。还能够获得key和value组成

的Map.Entry对象的集合。

8、介绍一下TreeSet

(1)TreeSet的原理

Tree在存储对象的时候须要排序。可是须要指定排序的算法。

Integer和String能够自己主动排序(有默认算法)

import java.util.*;

public class TreeSetDemo1 {

public static void main(String[] args) {

Set ts = new TreeSet();

ts.add(new Integer(5));

ts.add(new Integer(10));

ts.add(new Integer(1));

ts.add(new Integer(6));

ts.add(new Integer(2));

Iterator it = ts.iterator();

/**

* 结果打印的顺序是1 2 5 6 10是依照规律的顺序排列的,这是由于Integer类实现了Comparable接口

* 重写了它的compareTo()方法

*/

while (it.hasNext()) {

System.out.println(it.next());

}

}

}

注:Integer类中compareTo()方法的实现方式:

/**

* Compares two {@code Integer} objects numerically.

*

* @param anotherInteger the {@code Integer} to be compared.

* @return the value {@code 0} if this {@code Integer} is

* equal to the argument {@code Integer}; a value less than

* {@code 0} if this {@code Integer} is numerically less

* than the argument {@code Integer}; and a value greater

* than {@code 0} if this {@code Integer} is numerically

* greater than the argument {@code Integer} (signed

* comparison).

* @since 1.2

*/

public int compareTo(Integer anotherInteger) {

return compare(this.value, anotherInteger.value);

}

/**

* Compares two {@code int} values numerically.

* The value returned is identical to what would be returned by:

*

 

* Integer.valueOf(x).compareTo(Integer.valueOf(y))

*

*

* @param x the first {@code int} to compare

* @param y the second {@code int} to compare

* @return the value {@code 0} if {@code x == y};

* a value less than {@code 0} if {@code x < y}; and

* a value greater than {@code 0} if {@code x > y}

* @since 1.7

*/

public static int compare(int x, int y) {

return (x < y) ? -1 : ((x == y) ?

0 : 1);

}

自己定义的类存储的时候须要指定排序的算法,否则会出现异常。

假设想把自己定义的类存储到TreeSet对象中,那

么必须实现Comparable接口。重写它的compareTo()方法。在方法内定义比較大小的方法,依据大小关系,返回正数、负数或者0.

在使用TreeSet的add方法进行存储对象的时候就会自己主动调用compareTo()方法进行比較,依据比較结果依照二叉树的方式进行存储。

import java.util.Iterator;

import java.util.Set;

import java.util.TreeSet;

public class TreeSetDemo2 {

public static void main(String[] args) {

Set ts = new TreeSet();

ts.add(new Teacher(“zhangsan”, 1));

ts.add(new Teacher(“lisi”, 2));

ts.add(new Teacher(“wangmazi”, 3));

ts.add(new Teacher(“wangwu”,4));

ts.add(new Teacher(“mazi”, 3));

Iterator it = ts.iterator();

while (it.hasNext()) {

System.out.println(it.next());

}

}

}

class Teacher implements Comparable {

int num;

String name;

Teacher(String name, int num) {

this.num = num;

this.name = name;

}

public String toString() {

return “学号:” + num + “\t\t姓名:” + name;

}

//o中存放时的红黑二叉树中的节点,从根节点開始比較

public int compareTo(Object o) {

Teacher ss = (Teacher) o;

int result = num < ss.num ?

1 : (num == ss.num ? 0 : -1);//降序

//int result = num > ss.num ? 1 : (num == ss.num ? 0 : -1);//升序

if (result == 0) {

result = name.compareTo(ss.name);

}

return result;

}

}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/156473.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 线程池和队列学习,队列在线程池中的使用,什么是队列阻塞,什么是有界队列「建议收藏」

    线程池和队列学习,队列在线程池中的使用,什么是队列阻塞,什么是有界队列「建议收藏」线程池和队列学习,队列在线程池中的使用,什么是队列阻塞,什么是有界队列

  • 鸿蒙3部曲先看哪部,“隋唐三部曲”“鸿蒙三部曲”“斗罗四部曲”谁才是网文巅峰之作…

    鸿蒙3部曲先看哪部,“隋唐三部曲”“鸿蒙三部曲”“斗罗四部曲”谁才是网文巅峰之作…原标题:“隋唐三部曲”“鸿蒙三部曲”“斗罗四部曲”谁才是网文巅峰之作从网络小说诞生的那一刻起,续集就是一个绕不过去的话题,如同电视剧一样。一部网络小说红了之后,它的原作者很多时候会忍不住开发它的续集,形成一个系列,然后再现网文界。小编今天就给大家介绍一下网文界最为著名的三个系列:“隋唐三部曲”“鸿蒙三部曲”“斗罗四部曲”,它们都曾红极一时,写下了赫赫威名,是网文界绕不过去系列作品,也是把作品开发到…

  • python官网下载步骤-Python 下载及安装详细步骤

    python官网下载步骤-Python 下载及安装详细步骤安装python分三个步骤:*下载python*安装python*检查是否安装成功1、下载Python(2)选择下载的版本(3)点开Download后,找到下载文件Gzippedsourcetarball是Linux系统下载的版本XZcompressedsourcetarball是CentOS系统下载的版本注意Linux和CentOS自带python,一般不用再下载python。ma…

  • Linux之lsof命令

    Linux之lsof命令

  • matlab直方图绘制[通俗易懂]

    matlab直方图绘制[通俗易懂]x=[55,63,69,70,75,78,82,84,85,88,90,96,100];y=[1,2,1,6,4,7,2,1,3,2,4,2,1];bar(x,y)>>a=[54.5,64.5,74.5,84.5,94.5];>>b=[1,3,17,8,7];>>bar(a,b)barh():可以显示一个水平的条形图barh(a,b)bar3或bar3h:显示三维bar3(a,b)…

    2022年10月18日
  • 简单选择排序 C语言

    简单选择排序 C语言简单选择排序(SimpleSelectionSort)也称作直接选择排序。算法步骤:1)设待排序的记录存放在数组Data[1…n]中。第一趟从Data[1]开始,通过n-1次比较,从n个记录中选出关键字最小的记录,记为Data[k],交换Data[1]和Data[k]。2)第二趟从Data[2]开始,通过n-2次比较,从n-1个记录中选出关键字最小的记录,记为Data[k],交换Data[2]和Data[k]。3)依次类推,第i趟从Data[i]开始,通过n-i次比较,从n-i

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号