咖啡伴侶

          呆在上海
          posts - 163, comments - 156, trackbacks - 0, articles - 2

          Hash code

          Posted on 2010-03-03 16:03 oathleo 閱讀(1697) 評(píng)論(4)  編輯  收藏 所屬分類: Java
          如果兩個(gè)對(duì)象equal,那么它們的hashCode值一定要相同;2、如果兩個(gè)對(duì)象的hashCode相同,它們并不一定equal

          當(dāng)Set要添加新的元素時(shí),先調(diào)用這個(gè)元素的hashCode方法,就一下子能定位到它應(yīng)該放置的物理位置上。如果這個(gè)位置上沒(méi)有元素,它就可以直接存儲(chǔ)在 這個(gè)位置上,不用再進(jìn)行任何比較了;如果這個(gè)位置上已經(jīng)有元素了,就調(diào)用它的equals方法與新元素進(jìn)行比較,相同的話就不存了,不相同就散列其它的地址。

          所以兩個(gè)不equal的對(duì)象,有相同的hash,是可以存進(jìn)Set的。

          class HashNode {
              int id;
             
              public HashNode(int id){
                  this.id = id;
              }
             
              public int hashCode() {
                  return id;
              }
             
              public boolean equals(Object obj) {
                  return false;
              }
          }

          public class HashTest {

              public static void main(String[] args) {
                  HashNode n1 = new HashNode(1);
                  HashNode n2 = new HashNode(1);
                 
                  HashMap map = new HashMap();
                  map.put(n1, "111");
                  map.put(n2, "222");
                 
                  System.out.println(n1.equals(n2));
                  System.out.println(n1.hashCode() == n2.hashCode());
                  System.out.println(map.keySet().size());
              }

          }

          Feedback

          # re: Hash code  回復(fù)  更多評(píng)論   

          2010-03-16 21:42 by 張貝貝
          比較兩個(gè)對(duì)象是不是得重寫equals方法啊?

          # re: Hash code  回復(fù)  更多評(píng)論   

          2010-03-17 08:41 by oathleo
          @張貝貝
          比較 是指?如果是內(nèi)容的比較 肯定是要重寫了。這種情況也是最常見(jiàn)的。
          當(dāng)然如果單純比較 內(nèi)存地址(或者說(shuō)對(duì)象引用本身) 就沒(méi)有必要了

          # re: Hash code  回復(fù)  更多評(píng)論   

          2010-03-17 20:31 by 張貝貝
          嗯,很對(duì),再問(wèn)一點(diǎn),內(nèi)存地址一樣,是不是內(nèi)容就一定一樣了?

          # re: Hash code  回復(fù)  更多評(píng)論   

          2010-03-18 18:24 by oathleo
          @張貝貝
          門牌號(hào)一樣,房子里面的人必然的一樣。
          主站蜘蛛池模板: 宿州市| 金华市| 临湘市| 漾濞| 郴州市| 惠州市| 准格尔旗| 闸北区| 安乡县| 临洮县| 绥化市| 梁平县| 缙云县| 石狮市| 福建省| 城固县| 库车县| 左权县| 舟山市| 深泽县| 普陀区| 武山县| 满洲里市| 柳河县| 鄯善县| 科技| 托里县| 柘城县| 韩城市| 武城县| 宣化县| 许昌市| 大姚县| 平舆县| 合川市| 五家渠市| 通州区| 汾西县| 渑池县| 团风县| 濮阳县|