In a language such as Go, where you can build in asynchronous operations and parallelism, it becomes important to consider things such as thread safety. For example, it is dangerous to access a map from multiple Goroutines simultaneously. Go provides a number of helpers in the sync and sync/atomic packages to make sure that certain events occur only once, or that Goroutines can serialize on an operation.
This recipe will demonstrate the use of these packages to safely modify a map with various Goroutines and to keep a global ordinal value that can be safely accessed by numerous Goroutines. It will also showcase the Once.Do method, which can be used to ensure that something is only done by a Go application once, such as reading a configuration file or initializing a variable.
How to do it...
These steps cover writing and running your application:
- From your Terminal or console application,createa new directory...