Hashcode could be a first-round check for inequality. However, it presents some tradeoffs.
String
hashcodes are lazily calculated, although they do use a “guard” value. If you’re comparing strings with long lifetimes (ie, they’re likely to have had the hashcode computed), this isn’t a problem. Otherwise, you’re stuck with either computing the hashcode (potentially expensive) or ignoring the check when the hashcode hasn’t been computed yet. If you have a lot of short-lived strings, you’ll be ignoring the check more often than you’ll be using it.- In the real world, most strings differ in their first few characters, so you won’t save much by checking hashcode first. There are, of course, exceptions (such as URLs), but again, in real world programming they occur infrequently.