samber/lo 库的使用方法:Error

2024-02-24 06:44
文章标签 使用 方法 error lo samber

本文主要是介绍samber/lo 库的使用方法:Error,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

samber/lo 库的使用方法:Error

samber/lo 是一个 Go 语言库,提供了一些常用的集合操作函数,如 Filter、Map 和 FilterMap。
这个库函数太多,因此我决定按照功能分别介绍,本文介绍的是 samber/lo 库中Error相关的函数。汇总目录页面

Validate

当条件不满足时,创建一个错误。

slice := []string{"a"}
val := lo.Validate(len(slice) == 0, "Slice should be empty but contains %v", slice)
// error("Slice should be empty but contains [a]")slice := []string{}
val := lo.Validate(len(slice) == 0, "Slice should be empty but contains %v", slice)
// nil

[play]

Must

对函数调用进行包装,函数的返回需要两个参数,第一个是值,第二个是错误。如果第二个参数是错误或者false,那么就会panic,否则返回值。

val := lo.Must(time.Parse("2006-01-02", "2022-01-15"))
// 2022-01-15val := lo.Must(time.Parse("2006-01-02", "bad-value"))
// panics

[play]

Must{0->6}

和Must一样,但是返回多个值。

func example0() (error)
func example1() (int, error)
func example2() (int, string, error)
func example3() (int, string, time.Date, error)
func example4() (int, string, time.Date, bool, error)
func example5() (int, string, time.Date, bool, float64, error)
func example6() (int, string, time.Date, bool, float64, byte, error)lo.Must0(example0())
val1 := lo.Must1(example1())    // alias to Must
val1, val2 := lo.Must2(example2())
val1, val2, val3 := lo.Must3(example3())
val1, val2, val3, val4 := lo.Must4(example4())
val1, val2, val3, val4, val5 := lo.Must5(example5())
val1, val2, val3, val4, val5, val6 := lo.Must6(example6())

可以包装像func (...) (..., ok bool)这样的函数。当ok为false时,会panic。

// math.Signbit(float64) bool
lo.Must0(math.Signbit(v))// bytes.Cut([]byte,[]byte) ([]byte, []byte, bool)
before, after := lo.Must2(bytes.Cut(s, sep))

可以通过添加一些类似printf的参数来给panic消息添加上下文。

val, ok := lo.Find(myString, func(i string) bool {return i == requiredChar
})
lo.Must0(ok, "'%s' must always contain '%s'", myString, requiredChar)list := []int{0, 1, 2}
item := 5
lo.Must0(lo.Contains[int](list, item), "'%s' must always contain '%s'", list, item)
...

[play]

Try

调用函数,如果出现错误或者panic,返回false。

ok := lo.Try(func() error {panic("error")return nil
})
// falseok := lo.Try(func() error {return nil
})
// trueok := lo.Try(func() error {return fmt.Errorf("error")
})
// false

[play]

Try{0->6}

和Try一样,但是回调函数返回对应数量的变量。

ok := lo.Try2(func() (string, error) {panic("error")return "", nil
})
// false

[play]

TryOr

调用函数,如果出现错误或者panic,返回默认值。

str, ok := lo.TryOr(func() (string, error) {panic("error")return "hello", nil
}, "world")
// world
// falsestr, ok := lo.TryOr(func() error {return "hello", nil
}, "world")
// hello
// truestr, ok := lo.TryOr(func() error {return "hello", fmt.Errorf("error")
}, "world")
// world
// false

[play]

TryOr{0->6}

和TryOr一样,但是回调函数返回对应数量的变量及error。

str, nbr, ok := lo.TryOr2(func() (string, int, error) {panic("error")return "hello", 42, nil
}, "world", 21)
// world
// 21
// false

[play]

TryWithErrorValue

和Try一样,但是返回传给panic的值。

err, ok := lo.TryWithErrorValue(func() error {panic("error")return nil
})
// "error", false

[play]

TryCatch

和Try一样,但是在出现错误时调用catch函数。

caught := falseok := lo.TryCatch(func() error {panic("error")return nil
}, func() {caught = true
})
// false
// caught == true

[play]

TryCatchWithErrorValue

TryWithErrorValue一样,但是在出现错误时调用catch函数。

caught := falseok := lo.TryCatchWithErrorValue(func() error {panic("error")return nil
}, func(val any) {caught = val == "error"
})
// false
// caught == true

[play]

ErrorsAs

是一个快捷方式,相当于:

err := doSomething()var rateLimitErr *RateLimitError
if ok := errors.As(err, &rateLimitErr); ok {// retry later
}

lo实现:

err := doSomething()if rateLimitErr, ok := lo.ErrorsAs[*RateLimitError](err); ok {// retry later
}

[play]

汇总目录页面

这篇关于samber/lo 库的使用方法:Error的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/741267

相关文章

gitlab安装及邮箱配置和常用使用方式

《gitlab安装及邮箱配置和常用使用方式》:本文主要介绍gitlab安装及邮箱配置和常用使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.安装GitLab2.配置GitLab邮件服务3.GitLab的账号注册邮箱验证及其分组4.gitlab分支和标签的

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

nginx启动命令和默认配置文件的使用

《nginx启动命令和默认配置文件的使用》:本文主要介绍nginx启动命令和默认配置文件的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录常见命令nginx.conf配置文件location匹配规则图片服务器总结常见命令# 默认配置文件启动./nginx

在Windows上使用qemu安装ubuntu24.04服务器的详细指南

《在Windows上使用qemu安装ubuntu24.04服务器的详细指南》本文介绍了在Windows上使用QEMU安装Ubuntu24.04的全流程:安装QEMU、准备ISO镜像、创建虚拟磁盘、配置... 目录1. 安装QEMU环境2. 准备Ubuntu 24.04镜像3. 启动QEMU安装Ubuntu4

使用Python和OpenCV库实现实时颜色识别系统

《使用Python和OpenCV库实现实时颜色识别系统》:本文主要介绍使用Python和OpenCV库实现的实时颜色识别系统,这个系统能够通过摄像头捕捉视频流,并在视频中指定区域内识别主要颜色(红... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间详解

Windows下C++使用SQLitede的操作过程

《Windows下C++使用SQLitede的操作过程》本文介绍了Windows下C++使用SQLite的安装配置、CppSQLite库封装优势、核心功能(如数据库连接、事务管理)、跨平台支持及性能优... 目录Windows下C++使用SQLite1、安装2、代码示例CppSQLite:C++轻松操作SQ

Python常用命令提示符使用方法详解

《Python常用命令提示符使用方法详解》在学习python的过程中,我们需要用到命令提示符(CMD)进行环境的配置,:本文主要介绍Python常用命令提示符使用方法的相关资料,文中通过代码介绍的... 目录一、python环境基础命令【Windows】1、检查Python是否安装2、 查看Python的安

Python并行处理实战之如何使用ProcessPoolExecutor加速计算

《Python并行处理实战之如何使用ProcessPoolExecutor加速计算》Python提供了多种并行处理的方式,其中concurrent.futures模块的ProcessPoolExecu... 目录简介完整代码示例代码解释1. 导入必要的模块2. 定义处理函数3. 主函数4. 生成数字列表5.

Python中help()和dir()函数的使用

《Python中help()和dir()函数的使用》我们经常需要查看某个对象(如模块、类、函数等)的属性和方法,Python提供了两个内置函数help()和dir(),它们可以帮助我们快速了解代... 目录1. 引言2. help() 函数2.1 作用2.2 使用方法2.3 示例(1) 查看内置函数的帮助(

Linux脚本(shell)的使用方式

《Linux脚本(shell)的使用方式》:本文主要介绍Linux脚本(shell)的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录概述语法详解数学运算表达式Shell变量变量分类环境变量Shell内部变量自定义变量:定义、赋值自定义变量:引用、修改、删