You have no excuses now, use this free credit to launch your projects now on Digital Ocean.
Table of contents
Golang maps or dictionaries
Golang maps or dictionaries
In the go programming language, a map or hash table is the equivalent of a dictionary; they have a key that is related to a value. The key and value can be of different data types, but all keys must be of a single type and all values must be of the same type.
Together with the array and the go slice , golang maps are structures that serve as a collection of values.
Inner workings of golang maps
In go a map works quite similar to any other language. In go there are buckets, a type of section consisting of 8 key-value pairs. The hash function receives the key and redirects us to the appropriate bucket, that is, the space of 9 key-value pairs where our key is located and, once there, it looks for the correct key.
Internal operation of golang maps. The information is taken from the official documentation of a map .
To declare a map, we use the word map and enclose the data type of the key in square brackets, followed by the data type of the value.
var dictionary map[string]int
//A map with key of string type and values of int type
dictionary["hello"] = 0
dictionary["panic"] = 1
fmt.Println(dictionary)
// panic: assignment to entry in nil map
However, if we execute the previous thing it will give us an error. Why? It is important that you know that golang maps are references, they point to a memory location, as we create an empty map it points to nothing, to nil, so if we try to modify it, it will give us an error.
As with the slice, we have two ways to create a map or dictionary.
- Passing values after the data type of the value
- Using the make function.
Create a map in go with values
We can create a map or dictionary using map, the data type of the braces in square brackets, followed by the data type of the values and then the data key value in square brackets, separating each one with a colon.
The map keys can be modified and even new ones can be added.
var account = map[string]int{
"Anna": 100,
"Renee": 200,
"Kakuro": 300,
"Joy": 400,
}
account["Anna"] = 500
account["Colombe"] = 900
We can also let go infer that it is a map, but only within a function, using the walrus operator “:=”.
account := map[string]int{
"Anna": 100,
"Renee": 200,
"Kakuro": 300,
"Joy": 400,
}
account["Anna"] = 500
account["Colombe"] = 900
Create a map in go with make
To create a map by allocating memory we need to use the make function and specify the type of data that the keys and values will have after the word map.
In this case we do not have to pass the map length argument to make. If we omit the map size, internally, go will assign a small value to it.
var dictionary = make(map[string]int)
dictionary["hello"] = 2
dictionary["world"] = 1
fmt.Println(dictionary)
// map[hello:2 world:1]
Now watch this! We have a map or dictionary with only two keys, see what happens if we access a third one.
fmt.Println(balance["user"])
// 0
// How can we distinguish between a zero balance or a user that doesn't exist
If we try to access a key that does not exist, go will return its respective zero value, but this leads us to a problem: how do we distinguish whether we have a zero because the key does not exist or because the value of our key is zero?
Distinguish between non-existent and zero values
To distinguish between a zero value, go provides a second return value, which indicates whether a key exists. This second value is a boolean: true or false.
value, exist := dictionary["NonExistent"]
Optional capacity in golang maps
To set a maximum key capacity in a map, we pass the length of the map as the second argument.
m := make(map[string]int,99)
However, unlike slices, this length only tells the compiler to allocate a minimum amount of memory; if we add more keys than the maximum value, they will still be added, although not as efficiently.
Delete keys with delete
If we want to get rid of a key from our map, we use the delete, function, which deletes a key from a map or dictionary.
delete(dictionary, "hello")
Why not go beyond Go's fundamentals to something more advanced
AdThe other day I found this Go course that you could find handy so now I'm sharing it with you, it deals with Go's core constructs, advanced concepts like error-handling and networking, efficient programming techniques and common pitfalls of this badass language.
Traverse golang maps with range
Just as with an array or a slice, we can tour a map using range. Each iteration will return the key and value.
Remember that, being a map, the elements will be returned in no particular order.
for key, value := range dictionary {
fmt.Println(key,value)
}
This is the minimum you should know about golang maps or dictionaries.