Home > Article > Backend Development > Error handling and recovery strategies in Go concurrent programming
There are two methods of error handling in concurrent programming: active error handling (propagation of errors) and passive error handling (error pipeline). There are two recovery strategies: recovery (catch panic) and retry (multiple executions). Practical cases demonstrate the use of these four methods.
In Go concurrent programming, error handling is crucial . There are two main approaches to handling errors:
In addition to error handling, there are also recovery strategies in concurrent programming. Recovery strategies are actions taken when a function fails to execute properly due to an error. There are two common recovery strategies:
recover
function. func CalculateAverage(numbers []int) (float64, error) { if len(numbers) == 0 { return 0, errors.New("empty slice") } sum := 0 for _, number := range numbers { sum += number } return float64(sum) / float64(len(numbers)), nil } func main() { numbers := []int{1, 2, 3, 4, 5} average, err := CalculateAverage(numbers) if err != nil { fmt.Println(err) return } fmt.Println(average) }
type ErrorChannel chan error func CalculateAverageWithChannel(numbers []int) ErrorChannel { ch := make(ErrorChannel) go func() { if len(numbers) == 0 { ch <- errors.New("empty slice") return } sum := 0 for _, number := range numbers { sum += number } ch <- nil close(ch) }() return ch } func main() { numbers := []int{1, 2, 3, 4, 5} ch := CalculateAverageWithChannel(numbers) for err := range ch { if err != nil { fmt.Println(err) return } fmt.Println("Average calculated successfully") } }
func CalculateAverageWithRecovery(numbers []int) float64 { defer func() { if r := recover(); r != nil { fmt.Println("Error occurred:", r) } }() if len(numbers) == 0 { panic("empty slice") } sum := 0 for _, number := range numbers { sum += number } return float64(sum) / float64(len(numbers)) } func main() { numbers := []int{1, 2, 3, 4, 5} average := CalculateAverageWithRecovery(numbers) fmt.Println(average) }
func CalculateAverageWithRetry(numbers []int) (float64, error) { var err error = errors.New("empty slice") maxRetries := 3 for i := 0; i < maxRetries; i++ { if len(numbers) == 0 { err = errors.New("empty slice") continue } sum := 0 for _, number := range numbers { sum += number } return float64(sum) / float64(len(numbers)), nil } return 0, err } func main() { numbers := []int{1, 2, 3, 4, 5} average, err := CalculateAverageWithRetry(numbers) if err != nil { fmt.Println(err) } else { fmt.Println(average) } }
The above is the detailed content of Error handling and recovery strategies in Go concurrent programming. For more information, please follow other related articles on the PHP Chinese website!