A preliminary exploration of generics in Go1.18
#The function we want to implement today is: sum all the values in the map.
Non-generic function
How to implement it if there is no generic type? Because value may have different types, such as: int64, float64, etc., without generics, different types need to be implemented through different functions, so we generally implement it as follows:
func SumInts(m map[string]int64) int64 { var s int64 for _, v := range m { s += v } return s } func SumFloats(m map[string]float64) float64 { var s float64 for _, v := range m { s += v } return s }
The above Code, we have defined two functions:
1. SumInts() calculates the sum of value as int64 type; 2. SumFloats() calculates the sum of value as float64 type;
The above function only It is suitable for int64 and float64 types. If we still want to calculate int, float32, etc., we have to re-copy the above function and modify the type.
Isn’t it a little troublesome to do this, and the code is very bloated? Not to mention, there are many similar codes in the previous standard package, such as the Sort package (sort.go) of the standard library in order to implement different types of slicing. Sorting, IntSlice, Float64Slice, StringSlice are defined.
Because the previous Go version did not support generics, it can only be implemented in this way, which is also the simplest method.
With generics, how can we implement a function to calculate the sum of values for different types of int64 and float64?
Generic function
#In this section we use a generic function to receive a map whose value is int64 type as a parameter, and also Can receive a map whose value is float64 type as parameter.
The complete code is as follows:
func Sum[K comparable, V int64 | float64](m map[K]V "K comparable, V int64 | float64") V { var s V for _, v := range m { s += v } return s } func main() { ints := map[string]int64{ "first": 1, "second": 2, } fmt.Println(Sum[string, int64](ints "string, int64")) floats := map[string]float64{ "first": 35.98, "second": 26.99, } fmt.Println(Sum[string, float64](floats "string, float64")) }
In the above code, we defined the Sum() function, which is a generic function. You can see that the difference from the ordinary function is that the function name and There is a set of square brackets [] between the function parameter list. There are two parameters K and V in the square brackets. They are called type parameters in the Go language. Following K and V are type restrictions. , where comparable is pre-declared by Go language and represents any type that can perform == and != operations. The type restriction of V is one of int64 and float64. The function parameter is m, the type is map[K]V, and the return type is V.
Calling a function is also a little different from calling an ordinary function. There is a set of square brackets [] between the function name and the actual parameters, indicating the type name. For example, when the Sum() function is called for the first time, the type names are string and int64 respectively. Then when the function is executed, the corresponding types of K and V are string and int64 respectively.
第二次调用该 Sum() 函数时,K、V 的类型分别是 string 和 float64。
通过泛型编程,我们就可以实现一个函数处理多种数据类型。
执行上面的代码输出:
3 62.97
The above is the detailed content of A preliminary exploration of generics in Go1.18. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics











In Go, WebSocket messages can be sent using the gorilla/websocket package. Specific steps: Establish a WebSocket connection. Send a text message: Call WriteMessage(websocket.TextMessage,[]byte("Message")). Send a binary message: call WriteMessage(websocket.BinaryMessage,[]byte{1,2,3}).

Go and the Go language are different entities with different characteristics. Go (also known as Golang) is known for its concurrency, fast compilation speed, memory management, and cross-platform advantages. Disadvantages of the Go language include a less rich ecosystem than other languages, a stricter syntax, and a lack of dynamic typing.

In Go, you can use regular expressions to match timestamps: compile a regular expression string, such as the one used to match ISO8601 timestamps: ^\d{4}-\d{2}-\d{2}T \d{2}:\d{2}:\d{2}(\.\d+)?(Z|[+-][0-9]{2}:[0-9]{2})$ . Use the regexp.MatchString function to check if a string matches a regular expression.

Memory leaks can cause Go program memory to continuously increase by: closing resources that are no longer in use, such as files, network connections, and database connections. Use weak references to prevent memory leaks and target objects for garbage collection when they are no longer strongly referenced. Using go coroutine, the coroutine stack memory will be automatically released when exiting to avoid memory leaks.

When passing a map to a function in Go, a copy will be created by default, and modifications to the copy will not affect the original map. If you need to modify the original map, you can pass it through a pointer. Empty maps need to be handled with care, because they are technically nil pointers, and passing an empty map to a function that expects a non-empty map will cause an error.

In Golang, error wrappers allow you to create new errors by appending contextual information to the original error. This can be used to unify the types of errors thrown by different libraries or components, simplifying debugging and error handling. The steps are as follows: Use the errors.Wrap function to wrap the original errors into new errors. The new error contains contextual information from the original error. Use fmt.Printf to output wrapped errors, providing more context and actionability. When handling different types of errors, use the errors.Wrap function to unify the error types.

There are two steps to creating a priority Goroutine in the Go language: registering a custom Goroutine creation function (step 1) and specifying a priority value (step 2). In this way, you can create Goroutines with different priorities, optimize resource allocation and improve execution efficiency.

Unit testing concurrent functions is critical as this helps ensure their correct behavior in a concurrent environment. Fundamental principles such as mutual exclusion, synchronization, and isolation must be considered when testing concurrent functions. Concurrent functions can be unit tested by simulating, testing race conditions, and verifying results.
