<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給我們提供了兩種判斷對象對等的方式。如果我們判斷兩個對象是否相等,那么直接用“==”運算就可以了。然而,判斷兩個對象對等,就沒有那么簡單了。
    在java中,我們常常通過equals()方法來判斷兩個對象的對等。其實,我么還可以通過hashCode()來判斷兩個對象的對等。

    看下面的例子:

    import java.util.List;

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

    所以,對于上面的MyBag的對象對等,那么,兩個對象的money要一樣,同時,books要對等。那么如何去判斷呢?我們通常會自己去實現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;
    ??? }

    我們也可以通過實現hashCode()來實現:
    ??? 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;
    ??? }

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

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

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

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

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



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

    FeedBack:
    # re: 對hashCode的一點簡單認識
    2008-04-23 16:48 | 懶人
    那hashtable是什么用的?  回復  更多評論
      
    主站蜘蛛池模板: 亚洲av永久无码精品三区在线4| 亚洲精品无码久久久久| 亚洲成人免费网站| 男人的天堂网免费网站| 亚洲av永久无码精品秋霞电影影院| 91av免费在线视频| 亚洲色WWW成人永久网址| 中文字幕免费在线看| 一本色道久久综合亚洲精品高清 | 国产精品视频免费观看| 亚洲精品在线电影| 免费毛片a在线观看67194| 久久综合给合久久国产免费| 久久久久亚洲av无码专区蜜芽| 日韩免费观看一区| 亚洲黄色在线观看| 啦啦啦中文在线观看电视剧免费版| 亚洲精品无码久久久影院相关影片 | 国产成人精品久久免费动漫| 亚洲av成人综合网| 最近2019中文免费字幕| 亚洲成a人片在线观看无码 | 亚洲国产成人久久综合一区77 | 亚洲精品宾馆在线精品酒店| 亚洲成aⅴ人片久青草影院| 精品国产免费人成网站| 亚洲AV日韩AV天堂久久| 一个人免费高清在线观看| 香港经典a毛片免费观看看| 亚洲色无码一区二区三区| 69视频在线是免费观看| 亚洲精品第一国产综合亚AV| 亚洲自偷自偷在线制服| 男人扒开添女人下部免费视频| 精品久久香蕉国产线看观看亚洲| 免费福利在线播放| 免费精品视频在线| 亚洲欧洲中文日产| 亚洲区日韩区无码区| 99久久精品免费精品国产| 亚洲精品美女久久久久久久|