登录
首页 >  Golang >  Go问答

正确处理缺失变量担忧的方法

来源:stackoverflow

时间:2024-03-08 08:54:24 412浏览 收藏

最近发现不少小伙伴都对Golang很感兴趣,所以今天继续给大家介绍Golang相关的知识,本文《正确处理缺失变量担忧的方法》主要内容涉及到等等知识点,希望能帮到你!当然如果阅读本文时存在不同想法,可以在评论中表达,但是请勿使用过激的措辞~

问题内容

我有以下简单的 go-lang 代码。

aud := claims["aud"].(string)

这是一个 jwt 声明,因此它始终存在。然后我尝试尝试将变量从 aud 更改为 missing-aud。

当我改变它,然后测试。我注意到一种严重的恐慌。

[panic recover] 接口转换:interface {} 为 nil,不是字符串 goroutine 7

处理缺失变量而不引起恐慌的最简单方法是什么?

我试过了,但好像不是这样。

var aud string
    if claims["audx"].(string) != "" {
        aud = claims["audx"].(string)
    }

感谢任何可以提供帮助的人

修改了答案,但正在寻找是否可以简化?

var aud string
    if _, found := claims["audx"].(string); found {
        aud = claims["audx"].(string)
    }

解决方案


正如 @jimb 指出的 - 您将类型断言 (claims["audx"].(string)) 与映射键存在检查 (v, ok := claims["audx"]) 混淆:

如果您的映射值的类型为 interface{} - 那么您需要类型断言。但在检查值之前您还需要进行密钥检查,例如

if v, ok := claims["audx"]; ok {

        log.printf("audx key exists")

        if vs, ok := v.(string); ok {
            // "audx" value is a string
            aud = vs
            log.printf("audx value is a string: %q", aud)
        }

}

这个演示示例应该更清楚:https://play.golang.org/p/pTOR39wDCx5

您的 if 语句的形式是有效的,并且可以在这里工作,但是 found 值不是您所期望的。它是类型断言的结果,而不是映射索引。

_, found := claims["audx"].(string)

可以分解为

v := claims["audx"]
_, ok := v.(string)

由于类型断言的零值对于您的目的是有效的,并且您不对索引或断言条件的结果采取任何操作,因此您可以将表达式简化为:

audx, _ := claims["audx"].(string)

这是有效的,因为如果映射返回 nil,类型断言就会失败,但会给您该类型的零值。

本篇关于《正确处理缺失变量担忧的方法》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>