java基础学习3

1.linkedlist中添加一个对象,并不是直接添加引用,而是生成一个entry对象,并添加到集合中去,llinkedlist中所维护的是一个个Entry对象,而不是添加的对象本身;

2.arraylist中添加一个对象,实际上是将该对象放到arraylist底层维护的一个数组当中去的;

3.关于object类的equals方法的特点:

a)自反性:x.equals(x)应该返回true

b)对称性:x.equals(y)为true,那么y.equals(y)也为true

c)传递性:x.equals(y)为true并且y.equals(z)为true,那么x.equals(z)也为true;

d)一致性:x.equals的第一次调用为true,那么x.equals(y)的第二次第三次,,,为true,前提比较之间没有修改;

e)对于非空引用x,x.equals(null)为false;

4.object比较是双等号;字符串比较是值的比较;

5.关于object类的hashCOde()方法特点:

a)在java应用的一次执行过程当中,对于同一个对象的hashCode方法的多次调用,他们应该返回同样的值(前提是该对象的信息没有发生变化);

b)对于两个对象来说,如果使用equals方法返回true,那么这两个对象的hashCode一定相同;

c)对于两个对象来说,如果使用eauals方法比较返回false,那么这两个对象的hashCode的值不要求一定不同(可以相同,可以不同),但是不同可以提高应用的性能;

d)对于Object类来说,不同的Object对象的hashCode值是不同的,object类的hashCode值标识的是对象的地址;

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

7.如果重写equals方法,那么也要重写hashCode()方法;

 

posted @   O-ll-O  阅读(75)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· .NET Core 中如何实现缓存的预热?
· 三行代码完成国际化适配,妙~啊~
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
点击右上角即可分享
微信分享提示