zoukankan      html  css  js  c++  java
  • java 关于hashcode和equals的测试

    package thinkingInJava;
    
    import java.util.HashMap;
    
    /*
     * 测试在向以hashcode为基础的集合(HashSet , HashMap , HashTable )中操作对象时,
     * 该对象的equals方法和hashcode方法的影响
     * 
     */
    class MapItem2 {
        private String title ;
        public MapItem2(String title ){
            this.title = title ;
        }
        public void setTitle(String title ){
            this.title = title ;
        }
        @Override
        public int hashCode() {
            return title.hashCode() ;
        }
    }
    public class TestEqualsAndHashcode {
        
        public static void main(String[] args) {
            // 向HashMap中添加对象
            /*
             * 1. 计算对象的hashcode
             * 2. 根据计算的hashcode将对象存储进对应的数组中
             * 3. 如果两个对象计算的hashcode相同,
             *    再通过equals方法判断两个对象是不是相等。
             *    如果equals方法返回true,这将已有对象覆盖掉。
             *    否则执行下一步操作
             * 4. 则将这两个对象存储在以该hashcode对应数组元素为头的链表上
             *          
             */
            HashMap hm = new HashMap() ;
            MapItem2 mi = new MapItem2("") ;
            //System.out.println("HashMap object hashcode : " + mi.hashCode());
            hm.put(hm, "xx") ;
            
            // 使用HashMap的get方法从HashMap中获取值
            /*
             * 1. 根据传递进来的对象计算其hash值,找到相应数组位置。
             * 2. 通过equals方法判断数组位置上的值是否与该值相等。
             * 3. 相等返回值,否则返回null。
             */
            /*
             * 测试: 使用对象的title属性的hashcode作为hashcode的返回值,
             * 然后将对象put到Map中,然后将title改变,再从Map中取值
             */
            HashMap hm2 = new HashMap() ;
            MapItem2 mi2 = new MapItem2("xxx") ;
            hm2.put(mi2 , "xxx") ;
            mi2.setTitle("yyyy") ;// 重新设置title值后就无法再获取xxx值了,因为在get时计算的hash值变了
            System.out.println(hm2.get(mi2)) ;  
        }
    }
  • 相关阅读:
    12. nc/netcat 用法举例
    7. 由一道ctf学习变量覆盖漏洞
    11. 几点基于Web日志的Webshell检测思路
    约瑟夫环
    栈结构的经典算法题
    二叉查找树之二
    fork与vfork
    数组常见算法题
    赛马问题
    fibonacci 数列及其应用
  • 原文地址:https://www.cnblogs.com/caiyao/p/4396624.html
Copyright © 2011-2022 走看看