码迷,mamicode.com
首页 > 其他好文 > 详细

String的equals和hashCode方法

时间:2018-11-03 12:32:11      阅读:104      评论:0      收藏:0      [点我收藏+]

标签:错误   set   har   this   ++   OLE   val   因此   思想   

对于判断对象是否相等,肯定需要重写它的equals和hashCode方法。不然使用默认的方法只会比较地址,因此会出现错误。

以String类为例,且看它的equals方法

    public boolean equals(Object anObject) {
    //比较地址
    if (this == anObject) {
        return true;
    }
    //看是否是String实例
    if (anObject instanceof String) {
        String anotherString = (String)anObject;
        int n = count;
        //比较字符串长度
        if (n == anotherString.count) {
        char v1[] = value;
        char v2[] = anotherString.value;
        int i = offset;
        int j = anotherString.offset;
        while (n-- != 0) {
            //比较字符是否相等
            if (v1[i++] != v2[j++])
            return false;
        }
        return true;
        }
    }
    return false;
    }          

主要思想:比较地址、比较长度、比较字符

hsahCode实现方式:

    public int hashCode() {
    int h = hash;
        int len = count;
    if (h == 0 && len > 0) {
        int off = offset;
        char val[] = value;

            for (int i = 0; i < len; i++) {
                h = 31*h + val[off++];
            }
            hash = h;
        }
        return h;
    }

 

String的equals和hashCode方法

标签:错误   set   har   this   ++   OLE   val   因此   思想   

原文地址:https://www.cnblogs.com/lidedong/p/9900033.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!