JAVA Object类方法
Object类详解
一、==和equals的对比
1.1 ==是一个比较运算符
- ==:即可以判断基本类型,又可以判断引用类型
- ==:如果判断基本类型,判断的是值是否相等
- 例如:int i = 10;double d = 10.0
- ==:如果判断应用类型,判断的是地址是否相等,即判断是否是一个对象
1.2 equals方法
- 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 提供的哈希表)的性能。
提供具有哈希结构的容器效率!
两个引用,如果指向的是同一个对象,则哈希值肯定是一样的!
两个引用,如果指向的是不同对象,则哈希值不一样的
哈希值主要根据地址来计算的,但不能将其等价为地址
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方法
当对象被回收时,系统自动调用该对象的 finalize 方法。子类可以重写该方法,做一些释放资源的操作
什么时候被回收: 当某个对象没有任何引用时,则 jvm 就认为这个对象是一个垃圾对象,就会使用垃圾回收机制来 销毁该对象,在销毁该对象前,会先调用 finalize 方法
垃圾回收机制的调用,是由系统来决定(即有自己的 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类方法的更多相关文章
- Java Object类方法解析
Java Object类方法解析 在Java中Object是所有类的父类,任何类都默认继承Object,其提供的方法主要有以下几种: registerNatives() hashCode和equale ...
- Java菜鸟学习笔记--面向对象篇(十六):Object类方法
Object类 什么是Object类? Object类是所有Java类的祖先,每个类都使用 Object 作为超类,所有对象(包括数组)都实现这个类的方法Object类是类层次结构的根,Object类 ...
- Java Object 引用传递和值传递
Java Object 引用传递和值传递 @author ixenos Java没有引用传递: 除了在将参数传递给方法(或函数)的时候是"值传递",传递对象引用的副本,在任何用&q ...
- Java Object 构造方法的执行顺序
Java Object 构造方法的执行顺序 @author ixenos 为了使用类而做的准备工作包括三个步骤 1)加载:类加载器查找字节码(一般在classpath中找),从字节码创建一个Class ...
- Java Object 对象创建的方式 [ 转载 ]
Java Object 对象创建的方式 [ 转载 ] @author http://blog.csdn.net/mhmyqn/article/details/7943411 显式创建 有4种显式地创建 ...
- Java Object 对象拷贝答疑
Java Object 对象拷贝答疑 @author ixenos 摘要:在对象的clone过程需要注意的几点.关于关键字this.super 关于clone[对象拷贝] 在实际编程过程,有时候我们会 ...
- Java Object 对象拷贝
Java Object 对象拷贝 @author ixenos JAVA 对象拷贝 Java里的clone分为: 1.浅拷贝:浅复制仅仅复制所考虑的对象,而不复制它所引用的对象,Object类里的c ...
- Java基础-SSM之Spring的POJO(Plain Old Java Object)实现AOP
Java基础-SSM之Spring的POJO(Plain Old Java Object)实现AOP 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 上次我分享过Spring传统的A ...
- java Object解析
java Object是所有对象的根父类,所有对象都直接或间接集成自该类. java 的Object类也比较简单,有equals(Object).toString().finalize() java方 ...
随机推荐
- JVM学习二:JVM之GC算法和种类
我们前面说到了JVM的常用的配置参数,其中就涉及了GC相关的知识,趁热打铁,我们今天就学习下GC的算法有哪些,种类又有哪些,让我们进一步的认识GC这个神奇的东西,帮助我们解决了C 一直挺头疼的内存回收 ...
- C语言设计ATM存取款界面
这个虽然很简单,但是我还是弄了一会儿,可见有多菜.练习算. 主要考察switch开关语句.do...while语句,页面的跳转我用的是goto,虽然是弊端,可是还是用了,因为太菜啊.大家有好建议的欢迎 ...
- redis lua脚本学习
语法格式(常见) a = 5 -- 全局变量 local b = 5 -- 局部变量 Eval的使用 EVAL script numkeys key [key ...] arg [arg ...] 首 ...
- .NET 云原生架构师训练营(权限系统 代码实现 ActionAccess)--学习笔记
目录 开发任务 代码实现 开发任务 DotNetNB.Security.Core:定义 core,models,Istore:实现 default memory store DotNetNB.Secu ...
- log4j和lockback的比较,二者可否同时使用
一.log4j和logback的介绍 log4j: 可以控制日志信息输送的目的地是控制台.文件.GUI组件,甚至是套接口服务器.NT的事件记录器.UNIX Syslog守护进程等:可以控制每一条日志的 ...
- ASP.NET Core 6框架揭秘实例演示[04]:自定义依赖注入框架
ASP.NET Core框架建立在一个依赖注入框架之上,已注入的方式消费服务已经成为了ASP.NET Core基本的编程模式.为了使读者能够更好地理解原生的注入框架框架,我按照类似的设计创建了一个简易 ...
- 32、python并发编程之背景知识
目录: 一 引子 二 为什么要有操作系统 三 什么是操作系统 四 操作系统与普通软件的区别 五 操作系统发展史 六 总结视频链接: 一 引子 顾名思义,进程即正在执行的一个过程.进程是对正在运行程序的 ...
- Note -「群论」学习笔记
目录 前置知识 群 置换 Burnside 引理与 Pólya 定理 概念引入 引例 轨道-稳定子(Orbit-Stabilizer)定理 证明 Burnside 引理 证明 Pólya 定理 证明 ...
- node(s) didn‘t match node selector.
k8s集群中,有pod出现了 Pending ,通过 kubectl describe pod 命令,发现了如下报错 0/4 nodes are available: 1 node(s) had ta ...
- linux大工程 - 我要一个属于自己的回收站
我要开始装13了 'rm -rf 是一个很"粗鲁"的命令,就像windows的shift+delete,删除的文件是无法找回的(当然,除了数据恢复软件,但是很麻烦,很费时)' '为 ...