HashCode giving negative values

前端 未结 3 1746
离开以前
离开以前 2020-12-02 17:21

I am converting the incoming string into hash code by doing the following function but some of the values are negative. I don\'t think hash values should be negative. Please

3条回答
  •  失恋的感觉
    2020-12-02 17:50

    I don't think hash values should be negative.

    Why not? It's entirely valid to have negative hash codes. Most ways of coming up with a hash code naturally end up with negative values, and anything dealing with them should take account of this. However, I'd consider a different approach to coming up with your hash codes, e.g.

    int hash = 17;
    hash = hash * 31 + srcadd.hashCode();
    hash = hash * 31 + dstadd.hashCode();
    hash = hash * 31 + sourceport; // I'm assuming this is an int...
    hash = hash * 31 + destinationport; // ditto
    hash = hash * 31 + protocol.hashCode();
    return hash;
    

    It's not clear what the types of these expressions are, but I'm guessing you're ending up taking the hash code of a string... a string that you don't really need to create in the first place. While there are better approaches for getting hash codes for known domains, the above approach works well as a general-purpose hash generation technique.

    Note that it would also help the readability of your code if you avoided abbreviations, and used camel casing, e.g. sourceAddress instead of srcadd.

提交回复
热议问题