<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    zhyiwww
    用平實的筆,記錄編程路上的點點滴滴………
    posts - 536,comments - 394,trackbacks - 0
    hashcode,一個不太好理解,也常被我們忽視的一個概念。然而,hashcode還有對我們有用的東西。
    java給我們提供了兩種判斷對象對等的方式。如果我們判斷兩個對象是否相等,那么直接用“==”運(yùn)算就可以了。然而,判斷兩個對象對等,就沒有那么簡單了。
    在java中,我們常常通過equals()方法來判斷兩個對象的對等。其實,我么還可以通過hashCode()來判斷兩個對象的對等。

    看下面的例子:

    import java.util.List;

    public class MyBag{
    ??? float money;
    ??? List books;??
    }
    我們?nèi)绾闻袛鄡蓚€MyBag對象是對等的呢?也就是說,如果有兩個MyBag的對象bag1和bag2,通過什么的辦法能說明這個兩個對象是相同的呢?
    先聲名兩個概念:
    兩個對象相等,指的是,兩個引用指向了同一個對象,也就是說,指向了內(nèi)存中的同一個地址。
    兩個對象相同(對等),指得是兩個對象的任何屬性都相等,但是,不是一個對象。

    所以,對于上面的MyBag的對象對等,那么,兩個對象的money要一樣,同時,books要對等。那么如何去判斷呢?我們通常會自己去實現(xiàn)equals()方法去判斷,方法如下:

    ??? public boolean equals(Object obj) {
    ??? ??? if (this == obj)
    ??? ??? ??? return true;
    ??? ??? if (obj == null)
    ??? ??? ??? return false;
    ??? ??? if (getClass() != obj.getClass())
    ??? ??? ??? return false;
    ??? ??? final MyBag other = (MyBag) obj;
    ??? ??? if (books == null) {
    ??? ??? ??? if (other.books != null)
    ??? ??? ??? ??? return false;
    ??? ??? } else if (!books.equals(other.books))
    ??? ??? ??? return false;
    ??? ??? if (Float.floatToIntBits(money) != Float.floatToIntBits(other.money))
    ??? ??? ??? return false;
    ??? ??? return true;
    ??? }

    我們也可以通過實現(xiàn)hashCode()來實現(xiàn):
    ??? public int hashCode() {
    ??? ??? final int prime = 31;
    ??? ??? int result = 1;
    ??? ??? result = prime * result + ((books == null) ? 0 : books.hashCode());
    ??? ??? result = prime * result + Float.floatToIntBits(money);
    ??? ??? return result;
    ??? }

    那么我們判斷兩個對象對等時,就可以這樣來實現(xiàn)了:
    if(bag1.equals(bag2)){
    ??? // 對等
    }

    或者
    if(bag1.haseCode()==bag2.hashCode()){
    ??? // 對等
    }

    為什么這種方式也能判斷兩個對象對等呢?
    因為,任何一個對象的hashCode是唯一的,并且和氣對象屬性按照一定的規(guī)則相關(guān)的。

    比如,一個Integer的hashCode值就是其整數(shù)值,因為Integer的haseCode()是這樣實現(xiàn)的:
    ??? public int hashCode() {
    ??? ??? return value;
    ??? }
    ??? public boolean equals(Object obj) {
    ??? ??? if (obj instanceof Integer)
    ??? ??? ??? return value == ((Integer) obj).intValue();
    ??? ??? else
    ??? ??? ??? return false;
    ??? }

    由此可以看到,也對象的HashCode是和其屬性有一定的聯(lián)系,規(guī)則和屬性的值有一定的聯(lián)系,這個規(guī)則決定了有相同的hashcode,就有兩個對象的屬性對等。



    |----------------------------------------------------------------------------------------|
                               版權(quán)聲明  版權(quán)所有 @zhyiwww
                引用請注明來源 http://www.tkk7.com/zhyiwww   
    |----------------------------------------------------------------------------------------|
    posted on 2008-04-22 18:03 zhyiwww 閱讀(1376) 評論(1)  編輯  收藏 所屬分類: java basic

    FeedBack:
    # re: 對hashCode的一點簡單認(rèn)識
    2008-04-23 16:48 | 懶人
    那hashtable是什么用的?  回復(fù)  更多評論
      
    主站蜘蛛池模板: 最近中文字幕完整免费视频ww| 成人免费黄色网址| 亚洲成a人无码av波多野按摩 | 一级特级女人18毛片免费视频| 亚洲国产高清在线一区二区三区| 一级毛片a免费播放王色电影 | 久视频精品免费观看99| 亚洲国产精品成人精品软件| 日韩高清在线免费看| 成人福利在线观看免费视频| 亚洲av中文无码乱人伦在线r▽| 久久久久久国产精品免费免费男同 | 亚洲国产精华液网站w| 最近最新高清免费中文字幕 | 亚洲第一页日韩专区| 色妞www精品视频免费看| 国产精品免费大片一区二区| 亚洲色WWW成人永久网址| 免费A级毛片无码专区| 亚洲精品综合在线影院| 永久免费A∨片在线观看| 亚洲精品日韩专区silk| 欧美a级在线现免费观看| 亚洲精品一品区二品区三品区 | 亚洲视频免费观看| 亚洲国产综合精品中文第一区| 最近2019中文字幕免费大全5| 亚洲免费综合色在线视频| 你是我的城池营垒免费看| 亚洲伊人久久大香线蕉苏妲己| 大陆一级毛片免费视频观看| 久久精品无码免费不卡| 亚洲一区二区三区深夜天堂 | 亚洲成AV人片在线观看无| 亚洲av日韩片在线观看| 最近中文字幕无免费视频| 99国产精品免费观看视频| 无码精品人妻一区二区三区免费 | 8x8x华人永久免费视频| 国产无限免费观看黄网站| 老司机午夜在线视频免费|