php中文网

Golang 函数:并发任务执行中的错误处理技术

php中文网

golang 并发任务错误处理技术包括:1. 返回值传递错误;2. 抛出异常;3. 使用通道传递错误。实战案例包括并发文件读取和 http 请求,通过通道传递错误,提高代码健壮性。

Go 语言函数:并发任务执行中的错误处理技术

在 Golang 中使用并发函数执行任务时,处理错误至关重要。本文介绍了多种错误处理技术,并提供了有关如何将它们应用于实际场景的实战案例。

错误处理技术

1. 返回值

最简单的方法是使用返回值来传递错误。函数可以返回错误值,调用者可以检查该值并采取适当的措施。

func getSum(a, b int) (int, error) {
    if a < 0 || b < 0 {
        return 0, errors.New("inputs must be non-negative")
    }
    return a + b, nil
}

2. 抛出异常

Go 语言提供了一个内置的异常机制。可以使用 panic 函数抛出异常,由调用者使用 recover 函数捕获。

立即学习“go语言免费学习笔记(深入)”;

func getArea(width, height int) (int, error) {
    if width < 0 || height < 0 {
        panic("invalid width or height")
    }
    return width * height, nil
}

3. channel

通道提供了另一种用于并发任务错误处理的机制。可以创建一个接收错误的 channel,然后将该 channel 传递给任务 goroutine。如果任务出错,goroutine 将向 channel 发送错误。

func getAverage(numbers []int) (float64, error) {
    errCh := make(chan error)

    go func() {
        sum := 0
        for _, n := range numbers {
            sum += n
        }

        avg := float64(sum) / float64(len(numbers))
        if len(numbers) == 0 {
            errCh <- errors.New("empty slice")
        } else {
            errCh <- nil
        }
    }()

    select {
    case err := <-errCh:
        return 0, err
    case <-time.After(1 * time.Second):
        return 0, errors.New("timeout")
    }
}

实战案例

文件读取并处理

以下函数使用并发 goroutine 读取并处理文件中的行。错误通过 channel 传递。

func processLines(filePath string) ([][]string, error) {
    errCh := make(chan error)

    file, err := os.Open(filePath)
    if err != nil {
        return nil, err
    }
    defer file.Close()

    lines := [][]string{}
    nLines := 0

    scanner := bufio.NewScanner(file)
    for scanner.Scan() {
        line := scanner.Text()
        nLines++

        go func(line string) {
            parts := strings.Split(line, ",")
            errCh <- processLine(parts)
        }(line)
    }

    for i := 0; i < nLines; i++ {
        err := <-errCh
        if err != nil {
            return nil, err
        }
    }

    return lines, nil
}

HTTP 请求并发

以下函数使用并发 goroutine 发出 HTTP 请求。错误通过返回的 channel 传递。

func sendRequests(urls []string) ([][]byte, error) {
    respCh := make(chan []byte, len(urls))
    errCh := make(chan error, len(urls))

    for _, url := range urls {
        go func(url string) {
            resp, err := http.Get(url)
            if err != nil {
                errCh <- err
            } else {
                defer resp.Body.Close()
                body, err := ioutil.ReadAll(resp.Body)
                if err != nil {
                    errCh <- err
                } else {
                    respCh <- body
                }
            }
        }(url)
    }

    responses := [][]byte{}
    for i := 0; i < len(urls); i++ {
        select {
        case resp := <-respCh:
            responses = append(responses, resp)
        case err := <-errCh:
            return nil, err
        }
    }

    return responses, nil
}

总结

通过了解并应用这些错误处理技术,您可以有效地在 Golang 并发任务中处理错误,从而提高代码的健壮性和可靠性。

以上就是Golang 函数:并发任务执行中的错误处理技术的详细内容,更多请关注php中文网其它相关文章!