java arraylist equal_java面试(ArrayList去重;hashcode与equals)

问题1、ArrayList去重

答:1、利用HashSet(不保证元素顺序一致)

HashSet不会存在相同的元素,可以利用这一点去除List中的重复元素

List beforeList = new ArrayList();

beforeList.add("sun");

beforeList.add("star");

beforeList.add("moon");

beforeList.add("earth");

beforeList.add("sun");

beforeList.add("earth");

Set middleHashSet = new HashSet(beforeList);

List afterHashSetList = new ArrayList(middleHashSet);

System.out.println(beforeList);

System.out.println(afterHashSetList);

2.利用LinkedHashSet (去重后顺序一致)

List beforeList = new ArrayList();

beforeList.add("sun");

beforeList.add("star");

beforeList.add("moon");

beforeList.add("earth");

beforeList.add("sun");

beforeList.add("earth");

Set middleLinkedHashSet = new LinkedHashSet(beforeList);

List afterHashSetList = new ArrayList(middleLinkedHashSet);

System.out.println(beforeList);

System.out.println(afterHashSetList);

问题2、java集合中hashcode与equals的作用

答:在JAVA语言中,判断两个对象是否相等,一般有两种方法,一种是hashcode(),另一种是equals(),这两个方法在判断准确性和效率上有很大的区别,下面章节详细说明:

hashCode()方法和equal()方法的作用其实一样,在Java里都是用来对比两个对象是否相等一致,那么equal()既然已经能实现对比的功能了,为什么还要hashCode()呢?

因为重写的equal()里一般比较全面比较复杂,这样效率就比较低,而利用hashCode()进行对比,则只要生成一个hash值进行比较就可以了,效率很高,那么hashCode()既然效率这么高为什么还要equal()呢?

因为hashCode()并不是完全可靠,有时候不同的对象他们生成的hashcode也会一样(生成hash值得公式可能存在的问题),所以hashCode()只能说是大部分时候可靠,并不是绝对可靠,所以我们可以得出:

1.equal()相等的两个对象他们的hashCode()肯定相等,也就是用equal()对比是绝对可靠的。

2.hashCode()相等的两个对象他们的equal()不一定相等,也就是hashCode()不是绝对可靠的。

所有对于需要大量并且快速的对比的话如果都用equal()去做显然效率太低,

所以解决方式是,每当需要对比的时候,首先用hashCode()去对比,

如果hashCode()不一样,则表示这两个对象肯定不相等(也就是不必再用equal()去再对比了),

如果hashCode()相同,此时再对比他们的equal(),

如果equal()也相同,则表示这两个对象是真的相同了,这样既能大大提高了效率也保证了对比的绝对正确性!

这种大量的并且快速的对象对比一般使用的hash容器中,比如hashset,hashmap,hashtable等等,

比如hashset里要求对象不能重复,则他内部必然要对添加进去的每个对象进行对比,而他的对比规则就是像上面说的那样,先hashCode(),

如果hashCode()相同,再用equal()验证,如果hashCode()都不同,则肯定不同,这样对比的效率就很高了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值