Object 类中的 hashCode()
- 提高具有哈希结构的容器的效率!
- 两个引用,如果指向的是同一个对象,则哈希值肯定是一样的!两个引用
- 如果指向的是不同对象,则哈希值是不一样的
- 哈希值主要根据地址号来的,不能完全将哈希值等价于地址。
- 案例演示:
package day03;
public class Demo2 {
public static void main(String[] args) {
C c = new C();
C c1 = new C();
C c2 = c1;
System.out.println("c.hashCode = " + c.hashCode());
System.out.println("c1.hashCode = " + c1.hashCode());
System.out.println("c2.hashCode = " + c2.hashCode());
}
}
class C{}
输出结果:
- 后面在集合中,hashCode如果需要的话,也会重写
Object 类中的 toString()
-
默认返回:
全类名 + @ + 哈希值的十六进制
子类往往重写toString
方法,用于返回对象的属性信息 -
重写
toString
方法,打印对象或拼接对象时,都会自动调用该对象的toString
形式。 -
当直接输出一个对象时,toString方法会被默认的调用
// Object 的 toString 源码
// (1)getClass().getName() 获取全类名:包名.类名
// (2)Integer.toHexString(hashCode()) 将对象的 hashCode 值转为 16 进制字符串
public String toString() {
return getClass().getName() + "@" + Integer.toHexString(hashCode());
}
Object 类中的 finalize 方法
- 当对象被回收时,系统自动调用该对象的
finalize
方法。子类可以重写该方法,做一些释放资源的操作【演示】 - 什么时候被回收:当某个对象没有任何引用时,则
jvm
就认为这个对象是一个垃圾对象,就会使用垃圾回收机制来销毁该对象,在销毁该对象前,会先调用finalize
方法。 - 垃圾回收机制的调用,是由系统来决定(即:有自己的算法),也可以通过
System.gc()
主动触发垃圾回收机制,测试:Car [name] - 我们在实际开发中,几乎不会运用
finalize
package day03;
public class Demo2 {
public static void main(String[] args) {
Car bmw = new Car("宝马");
// 此时,没有引用指向 car 对象,car 对象就是一个垃圾,垃圾回收器就会回收(销毁) car 对象
// 在销毁 car 对象之前,会调用该对象的 finalize 方法
// 程序员就可以在finalize中,写自己的业务逻辑代码(比如释放资源:数据库连接,或者打开文件..)
// 如果程序员不重写 finalize,那么就会调用 0bject 类的 finalize,即默认处理
// 如果程序员重写了 finalize,就可以实现自己的逻辑
bmw = null;
System.gc(); // 主动调用垃圾回收器
System.out.println("程序退出");
}
}
class Car{
private String name;
public Car(String name) {
this.name = name;
}
@Override
protected void finalize() throws Throwable {
System.out.println("我们销毁汽车" + name + ",释放了某些资源!");
}
}