黑马程序员——Java学习笔记(六)

本文详细解释了Java集合框架中的ArrayList与LinkedList的数据结构实现原理,包括元素存储方式、Entry对象构造过程及equals方法和hashCode方法的特点。同时讨论了如何在使用HashSet时调用hashCode方法以及重写equals方法时需要同步重写hashCode方法的重要性。
---------------------- ASP.Net+Android+IOS开发.Net培训、期待与您交流! ----------------------

 
1.  当向ArrayList添加一个对象时,实际上就是将该对象放置到了ArrayList底层所维护的数组当中;当向LinkedList中添加一个对象时,实际上LinkedList内部会生成一个Entry对象,该Entry对象的结构为:
                 Entry
                           {
                              Entry previous;
                             Object element;
                             Entry next;
                            }
其中的Object类型的元素element就是我们向LinkedList 中所添加的元素,然后Entry又构造好了向前与向后的引用previous、next,最后将生成的这个Entry对象加入到了链表当中。换句话说,LinkedList中所维护的是一个个的Entry对象。

2.  关于Object类的equals方法的特点
                          a)  自反性:x.equals(x)应该返回true 
                          b)  对称性:x.equals(y)为true,那么y.equals(x)也为true。
                          c)  传递性:x.equals(y)为  true并且y.equals(z)为true,那么x.equals(z)也应该为true。 
                          d)  一致性:x.equals(y)的第一次调用为true,那么x.equals(y)的第二次、第三次、第n次调用也应该为true,前提条件是在比较之间没有修改x也没有修改y。
                          e)  对于非空引用x,x.equals(null)返回false。
3.  关于Object类的hashCode()方法的特点: 
                          a)  在Java 应用的一次执行过程当中,对于同一个对象的hashCode方法的多次调用,他们应该返回同样的值(前提是该对象的信息没有发生变化)。
                          b)  对于两个对象来说,如果使用equals方法比较返回true,那么这两个对象的hashCode值一定是相同的。 
                          c)  对于两个对象来说,如果使用equals方法比较返回false,那么这两个对象的hashCode值不要求一定不同(可以相同,可以不同),但是如果不同则可以提高应用的性能。
                         d)  对于Object类来说,不同的Object对象的hashCode值是不同的(Object类的hashCode值表示的是对象的地址)。 
             

4.  当使用HashSet时,hashCode()方法就会得到调用,判断已经存储在集合中的对象的hash  code值是否与增加的对象的hash  code值一致;如果不一致,直接加进去;如果一致,再进行equals方法的比较,equals方法如果返回true,表示对象已经加进去了,就不会再增加新的对象,否则加进去。

5.  如果我们重写equals方法,那么也要重写hashCode方法,反之亦然。

6.  Map(映射):Map的keySet()方法会返回key的集合,因为Map的键是不能重复的,因此keySet()方法的返回类型是Set;而Map的值是可以重复的,因此values()方法的返回类型是Collection,可以容纳重复的元素。


 

---------------------- ASP.Net+Android+IOS开发.Net培训、期待与您交流! ----------------------详细请查看: http://edu.csdn.net
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值