java 单机接口限流处理方案
254
2022-09-04
java中Object类4种方法详细介绍
目录Object(四大方法):hashCode()方法:equals()方法:getClass()方法:toString()方法:总结
Object(四大方法):
文章干货满满,耐性看完~~何为Object?首先先来看看官方对Object的介绍:在这里附上java官方的查阅工具:https://docs.oracle.com/en/java/javase/17/docs/api/index.html
由官方介绍可见,object属于Java.lang包内的一个类,而且提供了很多种方法, Object 是类层次结构的根类。每个类都使用 Object 作为超类。所有对象(包括数组)都实现这个类的方法。简单的说Object类就是所有类的父类,包括我们所写的类,我们在使用类的时候就会利用Object类中的方法,之所以我们在日常学习和开发中见不到object这个类,是因为所有的父类都自动的继承了这个类,并且拥有object类的所有方法,并且可以对这些方法进行重写,达到我们的业务需求。
hashCode()方法:
hashCode()介绍:hashCode() 的作用是获取哈希码,也称为散列码;它实际上是返回一个int整 数。这个哈希码的作用是确定该对象在哈希表中的索引位置。
用法:
//新建一个HashTest类
public class HashTest {
}
//测试类
public class TestMain {
public static void main(String[] args) {
HashTest h = new HashTest();
int hash = h.hashCode(); //调用hashCode()方法
System.out.println(hash); //输出可以得到一串整数
}
}
//460141958
//这个数也就是哈希码,也称为散列码,
//作用是确定该对象在哈希表中的索引位置
equals()方法:
参考官方文档可知:equals(Object obj),需要传入一个对象所以这个方法的作用就是判断其他对象是否“等于”此对象,返回值也就是布尔类型。上代码:
public class HashTest {
} //还是使用那个类
public class TestMain {
public static void main(String[] args) {
HashTest h1 = new HashTest();
HashTest h2 = new HashTest(); //用一个类去创建两个对象,判断是否相等
System.out.println(h1.equals(h2)); //语法:h1.equals(h2)
}
}
//结果:false
到这里,很多人就会有疑问了,同样的一个类去创建两个对象,为什么会不一样呢?
OK,首先我们看一下equals的源码,看看它的判断原理是什么:
//equals源码
public boolean equals(Object obj) {
return (this == obj);
}
源码很简单,不就是两个==号,但是我们知道类的引用类型的数据,而用两个等于号去判断两个引用类型,是去判断两者的内存地址是否相同,当一个类去new一个新对象时,是在堆内存内开辟了一个新的空间,当去创建两个或者多个类的时候,每个类肯定有属于自己的空间,所有也有一个独一无二的地址,这就是为什么这个判断为什么不成立的原因。
但是比较对象的引用对于我们在实际开发中没有意义,我们一般还是要重写该方法,比如去判断两者的参数是否相等:
public class HashTest {
private int age;
public HashTest() {
}
public HashTest(int age) {
this.age = age;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
//重写equals方法,只要HashTest生成的对象,传入age参数相等,即可判断两者一致
//重写后的equals,就不在是去判断两者的地址是否相同
@Override
public boolean equals(Object obj){
HashTest h = (HashTest) obj; //多态
if(this.age == h.getAge()) {
return true;
}
return false;
}
}
//测试类:
public class TestMain {
public static void main(String[] args) {
HashTest h1 = new HashTest(5);
HashTest h2 = new HashTest(5);
System.out.println(h1.equals(h2));
}
}
//结果:true
//若吧其中一个age改成6:
public class TestMain {
public static void main(String[] args) {
HashTest h1 = new HashTest(5);
HashTest h2 = new HashTest(6);
System.out.println(h1.equals(h2));
}
}
//结果:flase
== 和 equals 的区别是什么?
== : 它的作用是判断两个对象的地址是不是相等。即,判断两个对象是不是同 一个对象。(基本数据类型== 比较的是值,引用数据类型 == 比较的是内存地址)
equals() : 它的作用也是判断两个对象是否相等。但它一般有两种使用情况:情况1:类没有重写equals() 方法。则通过 equals() 比较该类的两个对象时, 等价于通过“==”比较这两个对象。情况2:类重写了 equals() 方法。一般,我们都覆盖 equals() 方法来两个对象 的内容相等;若它们的内容相等,则返回 true (即,认为这两个对象相等)
hashCode()与equals()的相关规定:
如果两个对象相等,则hashcode一定也是相同的 两个对象相等,对两个对象分别调用equals方法都返回true, 两个对象有相同的hashcode值,它们也不一定是相等的。因此,equals 方法被重写过,则 hashCode 方法也必须被重写,hashCode() 的默认行为是对堆上的对象产生独特值。如果没有重写hashCode(),则该 class 的两个对象无论如何都不会相等(即使这两个对象指 向相同的数据)
getClass()方法:
返回此 Object 运行时的类,,获取对象的真实类的全名称比如在使用多态时,父类引用变量,使用getClass()方法就可以看到真实的类:
public class HashTest {
}
//测试类
public class TestcjbCEsdEcMain {
public static void main(String[] args) {
HashTest h1 = new HashTest();
System.out.println(h1.getClass()); //调用getClass()
}
}
输出值:class HashTest
这个就比较好理解,简单的说就是看当时使用该方法的对象,到底是哪个类。
还有一个应用场景,在使用多态的时候,在代码多的时候我们做不到用肉眼去找这个多态是用哪子类,即使找得到,也很浪费时间,那么getClass()方法就派上用场了:
//在polymorphismTest包下创建了Person类,作为父类
package polymorphismTest;
public class Person {
public void eat(){
System.out.println("我会吃饭");
}
}
//创建Student类,继承Person
package polymorphismTest;
public class Student extends Person{
@Override //重写父类eat方法
public void eat(){
System.out.println("我是学生,我也还吃饭");
}
}
//测试类
package polymorphismTest;
public class TestMain {
public static void main(String[] args) {
Person p = new Student(); //使用多态
p.eat(); //这里其实就是使用了Student子类的方法
System.out.println(p.getClass()); //查看p到底是什么类
}
}
//输出结果:
//我是学生,我也还吃饭
//class polymorphismTest.Student
用父类去引用子类的方法时,可以执行子类的方法,当用getClass()方法去查看,结果也是Student子类
不使用多态,使用类本身去创建对象时:
package polymorphismTest;
public class TestMain {
public static void main(String[] args) {
Person p = new Person(); //当这里不使用多态,而是使用本身的时候
p.eat();
System.out.println(p.getClass());
}
}
//我会吃饭
//class polymorphismTest.Person
//这里返回的就是Person类了
toString()方法:
返回一个字符串来标识当前对象对于这个方法,我们先来看看toString()源码:
public String toString() {
return getClass().getNamehttp://() + "@" + Integer.toHexString(hashCode());
}
其实也很简,就是 类名+符号@+对象的哈希码值
public class TestMain {
public static void main(String[] args) {
Person p = new Person();
System.out.println(p.toString());
}
}
//结果:polymorphismTest.Person@1b6d3586
但是这个返回值视乎没什么意义,所以,为了返回值有更多的意义,我们可以重写这个方法
总结
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~