Skip to main content

GetHashCode() in .NET Core

If you ever had to implement the Equals() method to compare two instances of a type in .NET, you had to implement the GetHashCode() method too.

The GetHashCode method returns a numeric value which is used to identify an object during equality testing. It can also serve as an index for an object in a collection. The purpose of the method is to create a key for hashtable.

It is by design useful for only one thing: putting an object in a hash table.

It is faster to use the return value of GetHashCode to determine whether two objects are equal than to call the default implementation of Equals on the object type.

In other words, GetHashCode is used to generate a unique identifier for an object that can be used to compare it with other objects. It is used internally by the .NET framework for quick comparisons.

If you had to implement the GetHashCode method, there were some rules that should be followed which could make it quite a challenge to implement it correctly:

  • Equal items have equal hashes
  • The integer returned by GetHashCode must never change while the object is contained in a data structure that depends on the hash code remaining stable
  • GetHashCode must never throw an exception, and must return
  • GetHashCode must be performant

To follow all those rules we had a lot of magic going one. Here is an example from one of our applications:

We see the usage of the unchecked keyword to gain some extra performance by stopping overflow checks, magic numbers like 5 and 397. Most of the developers just copy this code without any clue why we are doing this.

Starting from .NET Core 2.1, we can leave all this magic to the framework itself and use the built-in HashCode struct:

No more magic!

Remark: If you are still working with pre .NET Core 2.1 code, you can use the Microsoft.Bcl.HashCode NuGet package.

More information

Guidelines and rules for GetHashCode | Fabulous adventures in coding (ericlippert.com)

Object.GetHashCode Method (System) | Microsoft Learn

HashCode Struct (System) | Microsoft Learn

NuGet Gallery | Microsoft.Bcl.HashCode 1.1.1

Popular posts from this blog

Azure DevOps/ GitHub emoji

I’m really bad at remembering emoji’s. So here is cheat sheet with all emoji’s that can be used in tools that support the github emoji markdown markup: All credits go to rcaviers who created this list.

DevToys–A swiss army knife for developers

As a developer there are a lot of small tasks you need to do as part of your coding, debugging and testing activities.  DevToys is an offline windows app that tries to help you with these tasks. Instead of using different websites you get a fully offline experience offering help for a large list of tasks. Many tools are available. Here is the current list: Converters JSON <> YAML Timestamp Number Base Cron Parser Encoders / Decoders HTML URL Base64 Text & Image GZip JWT Decoder Formatters JSON SQL XML Generators Hash (MD5, SHA1, SHA256, SHA512) UUID 1 and 4 Lorem Ipsum Checksum Text Escape / Unescape Inspector & Case Converter Regex Tester Text Comparer XML Validator Markdown Preview Graphic Color B

Kubernetes–Limit your environmental impact

Reducing the carbon footprint and CO2 emission of our (cloud) workloads, is a responsibility of all of us. If you are running a Kubernetes cluster, have a look at Kube-Green . kube-green is a simple Kubernetes operator that automatically shuts down (some of) your pods when you don't need them. A single pod produces about 11 Kg CO2eq per year( here the calculation). Reason enough to give it a try! Installing kube-green in your cluster The easiest way to install the operator in your cluster is through kubectl. We first need to install a cert-manager: kubectl apply -f https://github.com/cert-manager/cert-manager/releases/download/v1.14.5/cert-manager.yaml Remark: Wait a minute before you continue as it can take some time before the cert-manager is up & running inside your cluster. Now we can install the kube-green operator: kubectl apply -f https://github.com/kube-green/kube-green/releases/latest/download/kube-green.yaml Now in the namespace where we want t