全部
常见问题
产品动态
精选推荐

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

管理 管理 编辑 删除

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

}

请登录后查看

小码二开 最后编辑于2024-10-02 17:13:13

快捷回复
回复
回复
回复({{post_count}}) {{!is_user ? '我的回复' :'全部回复'}}
排序 默认正序 回复倒序 点赞倒序

{{item.user_info.nickname ? item.user_info.nickname : item.user_name}} LV.{{ item.user_info.bbs_level }}

作者 管理员 企业

{{item.floor}}# 同步到gitee 已同步到gitee {{item.is_suggest == 1? '取消推荐': '推荐'}}
{{item.is_suggest == 1? '取消推荐': '推荐'}}
沙发 板凳 地板 {{item.floor}}#
{{item.user_info.title || '暂无简介'}}
附件

{{itemf.name}}

{{item.created_at}}  {{item.ip_address}}
{{item.like_count}}
{{item.showReply ? '取消回复' : '回复'}}
删除
回复
回复

{{itemc.user_info.nickname}}

{{itemc.user_name}}

回复 {{itemc.comment_user_info.nickname}}

附件

{{itemf.name}}

{{itemc.created_at}}
{{itemc.like_count}}
{{itemc.showReply ? '取消回复' : '回复'}}
删除
回复
回复
查看更多
797
{{like_count}}
{{collect_count}}
添加回复 ({{post_count}})

相关推荐

快速安全登录

使用微信扫码登录
{{item.label}} 加精
{{item.label}} {{item.label}} 板块推荐 常见问题 产品动态 精选推荐 首页头条 首页动态 首页推荐
取 消 确 定
回复
回复
问题:
问题自动获取的帖子内容,不准确时需要手动修改. [获取答案]
答案:
提交
bug 需求 取 消 确 定

微信登录/注册

切换手机号登录

{{ bind_phone ? '绑定手机' : '手机登录'}}

{{codeText}}
切换微信登录/注册
暂不绑定
CRMEB客服

CRMEB咨询热线 咨询热线

400-8888-794

微信扫码咨询

CRMEB开源商城下载 源码下载 CRMEB帮助文档 帮助文档
返回顶部 返回顶部
CRMEB客服