zoukankan      html  css  js  c++  java
  • Java连载57-equals重写、finalize方法、hashCode方法​

    一、关于java语言中如何比较两个字符串是否一致

    1.不能使用双等号来比较两个字符串是否相等,应该使用equals方法进行比较,如例子

    package com.bjpowernode.java_learning;
    
    ​
    
    public class D57_1_ {
    
      public static void main(String[] args){
    
        String s1 = new String("ABC");
    
        String s2 = new String("ABC");
    
        System.out.println(s1 == s2);//false,这是因为这个两个对象作比较,比较的是对象的地址
    
        System.out.println(s1.equals(s2));//equals方法才是比较字符串里面的值
    
       
    
      }
    
    }

    2.重写类的equals可以达到判断对象内部的是否一致的效果,而不是使用类原来的对比地址的作用

    package com.bjpowernode.java_learning;
    
    ​
    
    public class D56_2_equalsMethodAnalysis {
    
      public static void main(String[] args) {
    
        Object o1 = new Object();
    
        Object o2 = new Object();
    
        boolean b1 = o1.equals(o2);
    
        System.out.println(b1);
    
        Star56 s1 = new Star56(100,"xiaoming");
    
        Star56 s2 = new Star56(100,"xiaoming");
    
        System.out.println(s1.equals(s2));
    
        //这样比较出来的是false,因为比较的是两个对象的内存地址,但是这样显然是不符合我们的预期
    
        //其实我们想要比较的是两个对象里面的内容是不是一致的。于是我们重写
    
       
    
      }
    
    }
    
    class Star56{
    
      int id;
    
      String name;
    
      public Star56(int id,String name) {
    
        this.id = id;
    
        this.name = name;
    
      }
    
      public boolean equals(Object obj) {
    
        if(obj instanceof Star56) {//强制类型转换,必须先做判断,二者是否存在继承关系
    
          Star56 s = (Star56)obj;
    
          if (s.id == this.id && s.name.equals(this.name)) {
    
            return true;
    
          }
    
        }
    
        return false;
    
      }
    
    }
    
    ​

    二、finalize方法、hashCode方法​

    1.finalize方法每个java对象都有

    2.finalize方法不需要程序员去调用,由系统调用

    3.java对象如果没有更多的引用去指向它,则该java对象成为垃圾数据,等待垃圾回收器的回收,垃圾回收器在回收这个java对象之前那会自动调用该对象的​finalize方法。

    finalize方法是该对象啊马上就要被回收了,例如:需要释放资源,则可以在该方法中释放。

    package com.bjpowernode.java_learning;
    
    ​
    
    public class D57_2_MethodOfFinalize {
    
      public static void main(String[] args) {
    
        Person57 p1 = new Person57();
    
        p1 = null;//没有引用在指向它,等待被回收
    
        //程序员只能去“建议”垃圾回收器回收垃圾
    
        System.gc();//这个就是系统
    
       
    
        //使用hashcode方法,返回的是该对象的哈希值,java对象的内存地址经过哈希算法得到的int类型的值
    
        Person57 p2 = new Person57();
    
        System.out.println(p2.hashCode());
    
       
    
        //使用clone()方法,可以对一个对象进行复制一份,防止把原来的对象内容给破坏了
    
      }
    
    }
    
    class Person57{
    
      //重写Object方法中的fianlize方法
    
      public void fianlize() throws Throwable{//至于为什么这么写,暂时不用知道,因为源码中就是这样写的,我们重写里面的函数体就行了
    
        System.out.println(this + "马上就要被回收了");
    
        //可以重写finalize方法,比如里面重写给对象指定引用,以此来缓解,对象要被垃圾回收器回收
    
      }
    
    }
    
     

    三、源码:

    D57_1_CompareString.java

    D57_2_MethodOfFinalize.java

    地址:

    https://github.com/ruigege66/Java/blob/master/D57_1_CompareString.java

    https://github.com/ruigege66/Java/blob/master/D57_2_MethodOfFinalize.java

    2.CSDN:https://blog.csdn.net/weixin_44630050(心悦君兮君不知-睿)

    3.博客园:https://www.cnblogs.com/ruigege0000/

    4.欢迎关注微信公众号:傅里叶变换,个人公众号,仅用于学习交流,后台回复”礼包“,获取大数据学习资料

     

  • 相关阅读:
    loj1201(最大独立集)
    hdu4185+poj3020(最大匹配+最小边覆盖)
    【Leetcode】3Sum Closest
    【Leetcode】3Sum
    【Leetcode】Two Sum
    【Leetcode】Longest Consecutive Sequence
    【Leetcode】Median of Two Sorted Arrays
    【Leetcode】Search in Rotated Sorted Array II
    【Leetcode】Search in Rotated Sorted Array
    【Leetcode】Remove Duplicates from Sorted Array II
  • 原文地址:https://www.cnblogs.com/ruigege0000/p/11980490.html
Copyright © 2011-2022 走看看