Object类详解

一、==和equals的对比

1.1 ==是一个比较运算符

  1. ==:即可以判断基本类型,又可以判断引用类型
  2. ==:如果判断基本类型,判断的是值是否相等
    • 例如:int i = 10;double d = 10.0
  3. ==:如果判断应用类型,判断的是地址是否相等,即判断是否是一个对象

1.2 equals方法

  1. equals:是Object类中的方法,只能判断引用类型

重写equals方法

题目:判断两个 Person 对象的内容是否相等,如果两个 Person 对象的各个属性值都一样,则返回 true,反之 false

package com.hspedu.object_;

import java.util.Objects;

public class EqualsExercise {
public static void main(String[] args) {
Person person1 = new Person("jack", 10, '男');
Person person2 = new Person("jack", 10, '男'); System.out.println(person1.equals(person2));//false
}
} class Person {//extends object 中的equals
private String name;
private int age;
private char gender; //重写equals方法 @Override
public boolean equals(Object o) {
//如果比较的对象是同一个对象,则直接返回true
if (this == o) {
return true;
}
/* 自己写的
else if (o == null) {
return false;
} else if (o instanceof Person) {
Person p = (Person) o;
return p.getAge() == this.age && p.getName().equals(this.name)
&& p.getGender() == this.gender;
}else {
return false;
}*/ //老师的思路
if (o instanceof Person) {
Person p = (Person) o;
return p.getAge() == this.age && p.getName().equals(this.name)
&& p.getGender() == this.gender;
}
return false;
} @Override
public int hashCode() {
return Objects.hash(name, age, gender);
} public Person(String name, int age, char gender) {
this.name = name;
this.age = age;
this.gender = gender;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public int getAge() {
return age;
} public void setAge(int age) {
this.age = age;
} public char getGender() {
return gender;
} public void setGender(char gender) {
this.gender = gender;
}
}

二、hashCode方法

功能:返回该对象的哈希码值。支持此方法是为了提高哈希表(例如 java.util.Hashtable 提供的哈希表)的性能。

  1. 提供具有哈希结构的容器效率!

  2. 两个引用,如果指向的是同一个对象,则哈希值肯定是一样的!

  3. 两个引用,如果指向的是不同对象,则哈希值不一样的

  4. 哈希值主要根据地址来计算的,但不能将其等价为地址

    package com.hspedu.object_;
    
    public class HashCode_ {
    public static void main(String[] args) {
    AA obj1 = new AA();
    AA obj2 = new AA();
    AA obj3 = obj1;
    System.out.println("obj1.hashCode()="+obj1.hashCode());
    System.out.println("obj2.hashCode()="+obj2.hashCode());
    System.out.println("obj3.hashCode()="+obj3.hashCode());
    }
    } class AA{ }

    5.后面在集合中,hashCode 如果需要,则会重写

三、toString方法

功能:全类名(包名+类名)+@+哈希值的十六进制

  • 重写 toString 方法,打印对象或拼接对象时,都会自动调用该对象的 toString 形式
  • 当直接输出一个对象时,toString 方法会被默认调用
    • 比如:System.out.println(monster);

一般会用重写之后的toString方法会打印类名和其属性

package com.hspedu.object_;

public class ToString {
public static void main(String[] args) {
/*
Object 的toString() 源码
(1) getClass().getName() 全类名(包名+类名)
(2) Integer.toHexString(hashCode()) 将对象的hashCode值转成16进制字符串
public String toString() {
return getClass().getName() + "@" + Integer.toHexString(hashCode());
}
}*/ Monster monster = new Monster("小妖怪", "巡山", 1000);
System.out.println(monster.toString() + " hashcode=" +monster.hashCode());
//com.hspedu.object_.Monster@49e4cb85
System.out.println("==当直接输出一个对象时,toString 方法会被默认调用==");
System.out.println(monster);
}
} class Monster{
private String name;
private String job;
private double sal; //重写toString方法,输出对象的属性
//使用快捷键 alt+inset -> toString @Override
public String toString() {//重写后,一般是把对象的属性输出,当然程序员也可以自己定制
return "Monster{" +
"name='" + name + '\'' +
", job='" + job + '\'' +
", sal=" + sal +
'}';
} public Monster(String name, String job, double sal) {
this.name = name;
this.job = job;
this.sal = sal;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public String getJob() {
return job;
} public void setJob(String job) {
this.job = job;
} public double getSal() {
return sal;
} public void setSal(double sal) {
this.sal = sal;
}
}

四、finalize方法

  1. 当对象被回收时,系统自动调用该对象的 finalize 方法。子类可以重写该方法,做一些释放资源的操作

  2. 什么时候被回收: 当某个对象没有任何引用时,则 jvm 就认为这个对象是一个垃圾对象,就会使用垃圾回收机制来 销毁该对象,在销毁该对象前,会先调用 finalize 方法

  3. 垃圾回收机制的调用,是由系统来决定(即有自己的 GC 算法), 也可以通过 System.gc() 主动触发垃圾回收机制,测 试:Car [name

  • 我们在实际开发中,几乎不会运用 finalize , 所以更多就是为了应试
package com.hspedu.object_;

//演示 Finalize的用法
public class Finalize_ {
public static void main(String[] args) {
Car car = new Car("宝马"); //这时 car对象就是个垃圾,垃圾回收器就会回收(销毁)对象,在销毁对象前
//,会调用该对象的finalize方法
//程序员就可以在 finalize中,写自己的业务逻辑(比如释放资源:数据库连接,或者打开文件..)
//,如果不重写finalize,那么就会调用Object类的 finalize,即默认处理
//,如果重写了finalize,就可以实现自己的逻辑
car = null;
System.gc();
System.out.println("程序退出了....");
}
} class Car{
private String name; @Override
protected void finalize() throws Throwable {
System.out.println("我们销毁 汽车" + name);
System.out.println("释放了某些资源...");
} public Car(String name) {
this.name = name;
} }

JAVA Object类方法的更多相关文章

  1. Java Object类方法解析

    Java Object类方法解析 在Java中Object是所有类的父类,任何类都默认继承Object,其提供的方法主要有以下几种: registerNatives() hashCode和equale ...

  2. Java菜鸟学习笔记--面向对象篇(十六):Object类方法

    Object类 什么是Object类? Object类是所有Java类的祖先,每个类都使用 Object 作为超类,所有对象(包括数组)都实现这个类的方法Object类是类层次结构的根,Object类 ...

  3. Java Object 引用传递和值传递

    Java Object 引用传递和值传递 @author ixenos Java没有引用传递: 除了在将参数传递给方法(或函数)的时候是"值传递",传递对象引用的副本,在任何用&q ...

  4. Java Object 构造方法的执行顺序

    Java Object 构造方法的执行顺序 @author ixenos 为了使用类而做的准备工作包括三个步骤 1)加载:类加载器查找字节码(一般在classpath中找),从字节码创建一个Class ...

  5. Java Object 对象创建的方式 [ 转载 ]

    Java Object 对象创建的方式 [ 转载 ] @author http://blog.csdn.net/mhmyqn/article/details/7943411 显式创建 有4种显式地创建 ...

  6. Java Object 对象拷贝答疑

    Java Object 对象拷贝答疑 @author ixenos 摘要:在对象的clone过程需要注意的几点.关于关键字this.super 关于clone[对象拷贝] 在实际编程过程,有时候我们会 ...

  7. Java Object 对象拷贝

    Java Object 对象拷贝 @author ixenos JAVA 对象拷贝 Java里的clone分为:  1.浅拷贝:浅复制仅仅复制所考虑的对象,而不复制它所引用的对象,Object类里的c ...

  8. Java基础-SSM之Spring的POJO(Plain Old Java Object)实现AOP

    Java基础-SSM之Spring的POJO(Plain Old Java Object)实现AOP 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 上次我分享过Spring传统的A ...

  9. java Object解析

    java Object是所有对象的根父类,所有对象都直接或间接集成自该类. java 的Object类也比较简单,有equals(Object).toString().finalize() java方 ...

随机推荐

  1. JVM学习二:JVM之GC算法和种类

    我们前面说到了JVM的常用的配置参数,其中就涉及了GC相关的知识,趁热打铁,我们今天就学习下GC的算法有哪些,种类又有哪些,让我们进一步的认识GC这个神奇的东西,帮助我们解决了C 一直挺头疼的内存回收 ...

  2. C语言设计ATM存取款界面

    这个虽然很简单,但是我还是弄了一会儿,可见有多菜.练习算. 主要考察switch开关语句.do...while语句,页面的跳转我用的是goto,虽然是弊端,可是还是用了,因为太菜啊.大家有好建议的欢迎 ...

  3. redis lua脚本学习

    语法格式(常见) a = 5 -- 全局变量 local b = 5 -- 局部变量 Eval的使用 EVAL script numkeys key [key ...] arg [arg ...] 首 ...

  4. .NET 云原生架构师训练营(权限系统 代码实现 ActionAccess)--学习笔记

    目录 开发任务 代码实现 开发任务 DotNetNB.Security.Core:定义 core,models,Istore:实现 default memory store DotNetNB.Secu ...

  5. log4j和lockback的比较,二者可否同时使用

    一.log4j和logback的介绍 log4j: 可以控制日志信息输送的目的地是控制台.文件.GUI组件,甚至是套接口服务器.NT的事件记录器.UNIX Syslog守护进程等:可以控制每一条日志的 ...

  6. ASP.NET Core 6框架揭秘实例演示[04]:自定义依赖注入框架

    ASP.NET Core框架建立在一个依赖注入框架之上,已注入的方式消费服务已经成为了ASP.NET Core基本的编程模式.为了使读者能够更好地理解原生的注入框架框架,我按照类似的设计创建了一个简易 ...

  7. 32、python并发编程之背景知识

    目录: 一 引子 二 为什么要有操作系统 三 什么是操作系统 四 操作系统与普通软件的区别 五 操作系统发展史 六 总结视频链接: 一 引子 顾名思义,进程即正在执行的一个过程.进程是对正在运行程序的 ...

  8. Note -「群论」学习笔记

    目录 前置知识 群 置换 Burnside 引理与 Pólya 定理 概念引入 引例 轨道-稳定子(Orbit-Stabilizer)定理 证明 Burnside 引理 证明 Pólya 定理 证明 ...

  9. node(s) didn‘t match node selector.

    k8s集群中,有pod出现了 Pending ,通过 kubectl describe pod 命令,发现了如下报错 0/4 nodes are available: 1 node(s) had ta ...

  10. linux大工程 - 我要一个属于自己的回收站

    我要开始装13了 'rm -rf 是一个很"粗鲁"的命令,就像windows的shift+delete,删除的文件是无法找回的(当然,除了数据恢复软件,但是很麻烦,很费时)' '为 ...