Go to Learn Go之类型转换

简介: Go to Learn Go之类型转换

概述

在上一节的内容中,我们介绍了Go的错误处理,包括:errors包、返回错误、抛出异常、捕获异常等。在本节中,我们将介绍Go的类型转换。在Go语言中,类型转换是一种将一个值从一种类型转换为另一种类型的过程。类型转换主要有4种,分别为:断言类型转换、显式类型转换、隐式类型转换、强制类型转换。下面将分别进行介绍。

断言类型转换

在Go语言中,断言是一种类型转换,它可以将一个接口类型的值转换为具体的类型。断言在Go语言中通常用于类型检查和类型转换,其语法如下:

 value, ok := interfaceValue.(Type)

其中,interfaceValue是一个接口类型的值,Type是要转换的具体类型。断言将接口值转换为具体类型,并将转换后的值赋给value变量。同时,还返回一个布尔值ok,指示转换是否成功。注意:断言只能用于接口类型的值转换为具体类型,如果尝试将一个非接口类型的值进行断言,将会导致编译错误。

在下面的示例代码中,我们定义了一个接口类型的变量data,并将其赋值为66。然后,我们使用断言将data转换为int类型,并将转换后的值赋给value变量。如果转换成功,打印出转换后的值;否则,打印出转换失败的消息。接下来,我们尝试将data转换为string类型,并进行了类似的处理。

package main

import "fmt"

func main() {  
    var data interface{} = 66

    // 断言将接口值转换为int类型,输出:Convert to int success: 66
    value, ok := data.(int)
    if ok {
        fmt.Println("Convert to int success:", value)
    } else {
        fmt.Println("Convert to int  failed")
    }

    // 断言将接口值转换为string类型,输出:Convert to string failed
    value2, ok2 := data.(string)
    if ok2 {
        fmt.Println("Convert to string success:", value2)
    } else {
        fmt.Println("Convert to string failed")
    }
}

另外,我们还可以使用switch语句结合断言进行类型转换。通过将接口类型的值与特定类型的值进行比较,可以实现类型转换。具体如何使用,可参考下面的示例代码。

package main

import "fmt"

func main() {  
    var data interface{} = "Hello, World"

    // 断言switch,输出:Convert to string: Hello, World
    switch value := data.(type) {
    case int:
        fmt.Println("Convert to int:", value)
    case string:
        fmt.Println("Convert to string:", value)
    default:
        fmt.Println("Convert failed")
    }
}

注意:使用断言进行类型转换时,如果断言失败,将会进入default分支。因此,在使用断言时,建议始终添加default分支以处理可能的错误情况。

显式类型转换

显式类型转换可以通过使用类型转换操作符将一个值转换为指定的类型,其语法如下:

 type_name(expression)

其中,type_name为数据类型,expression为表达式或变量值。注意:类型转换可能会导致精度损失或溢出。因此,在进行类型转换时,需要确保目标类型能够容纳原始值的范围,否则可能会产生不正确的结果。

在下面的示例代码中,我们将一个float64类型的值66.66显式地转换为int类型,并将结果赋给变量y。由于int类型无法容纳小数部分,故转换后的值为66。

package main

import "fmt"

func main() {
    var x float64 = 66.66
    // 将float64类型的变量显式转换为int类型
    var y int = int(x)
    // 输出: 66
    fmt.Println(y)
}

隐式类型转换

隐式类型转换是指在表达式中自动进行的类型转换,这种类型转换通常发生在不同类型的数据之间进行运算时。Go语言会自动将它们转换成相同的类型,以确保表达式的合法性和正确性。要真正理解隐式类型转换,需要先了解下常量。

常量是指不能改变值的特殊变量,分为两种:未命名常量和命名常量。未命名常量只在编译期间存在,不会存储在内存中。命名常量存在于内存静态区,不允许修改。比如:const a = 66这条语句,66是未命名常量,a是命名常量;编译后,a的值固定为66,而等号右边的66不再存在。

除位运算、未命名常量外,运算符两边的操作数类型必须相同,否则会发生编译错误。如果运算符两边是不同类型的未命名常量,则隐式转换的优先级为:整数(int) < 字符型(rune) < 浮点数(float) < 复数(Complex)。

package main

import "fmt"

func main() {
    // 66和100的类型相同,不需要隐式类型转换
    const num1 = 66 / 100
    // 整数优先转换为浮点数100.0, 结果为0.66
    const num2 = 66 / 100.0
    
    const num3 int = 88
    // num3为命名常量,与1.5的数据类型不同,无法进行隐式类型转换,会发生编译错误
    const num4 = num3 * 1.5
    fmt.Println(num1, num2, num3, num4)
}

另外,兼容的类型可以进行隐式类型转换,不兼容的类型不能够进行隐式类型转换,具体可参考下面的示例代码。

package main

import "fmt"

func main() {
    // 类型相同,不需要隐式类型转换
    const num1 int = 66
    // 66.0即为66,类型兼容,可进行隐式类型转换
    const num2 int = 66.0
    // 类型不兼容,不能进行隐式类型转换,会发生编译错误
    const num3 int = 66.1

    // 类型相同,不需要隐式类型转换
    const num4 float64 = 66.0
    // 66即为66.0,类型兼容,可进行隐式类型转换
    const num5 float64 = 66
    fmt.Println(num1, num2, num3, num4, num5)
}

强制类型转换

在Go语言中,可以进行强制类型转换来将一个值转换为指定的类型,其语法如下:

 type_name(value)

其中,type_name是目标类型,value是要进行类型转换的值。

在下面的示例代码中,我们将浮点数a的值强制转换为int类型,并将结果赋值给变量b。注意:在进行强制类型转换时,可能会出现精度丢失或溢出等问题。因此,在进行强制类型转换时,需要小心处理可能出现的异常情况。

package main

import "fmt"

func main() {
    var a float64 = 3.14
    var b int = int(a)
    // 输出:3.14 3
    fmt.Println(a, b)
}

strconv包

strconv包是Go语言标准库中的一个包,它提供了字符串和基本数据类型之间的转换函数。这个包中的函数可以将字符串转换为不同的基本数据类型(比如:整数、浮点数等),也可以将基本数据类型转换为字符串。

以下是strconv包中一些常用的函数:

Atoi(s string) (int, error):将字符串s转换为对应的整数。如果转换失败,会返回一个错误值。

ParseInt(s string, base int, bitSize int) (int, error):将字符串s转换为对应的整数,并指定进制base和位数 bitSize。如果转换失败,会返回一个错误值。

ParseFloat(s string, bitSize int) (float64, error):将字符串s转换为对应的浮点数,并指定位数bitSize。如果转换失败,会返回一个错误值。

FormatInt(v int64, base int) string:将整数v转换为指定进制的字符串表示。

FormatFloat(v float64, fmt byte, prec, bitSize int) string:将浮点数v转换为字符串表示,并指定格式化选项 fmt、精度prec和位数bitSize。第二个参数fmt是格式化选项,'f'表示使用普通的浮点数格式。第三个参数prec是精度,-1表示使用尽可能多的精度。第四个参数bitSize是浮点数的位数,64位浮点数为float64。

关于这些函数具体如何使用,可以参考下面的示例代码。

package main

import "fmt"
import "strconv"

func main() {
    // 将字符串转换为整数,输出:66
    num, err := strconv.Atoi("66")
    if err != nil {
        fmt.Println("Failed:", err)
    } else {
        fmt.Println(num)
    }

    // 将字符串转换为浮点数,输出:3.14
    fnum, err := strconv.ParseFloat("3.14", 64)
    if err != nil {
        fmt.Println("Failed:", err)
    } else {
        fmt.Println(fnum)
    }
    
    // 将整数转换为字符串,输出:99
    str := strconv.Itoa(99)
    fmt.Println(str)

    // 将浮点数转换为字符串,输出:2.718
    str = strconv.FormatFloat(2.71828, 'f', 3, 64)
    fmt.Println(str)
}


相关文章
|
12天前
|
弹性计算 人工智能 架构师
阿里云携手Altair共拓云上工业仿真新机遇
2024年9月12日,「2024 Altair 技术大会杭州站」成功召开,阿里云弹性计算产品运营与生态负责人何川,与Altair中国技术总监赵阳在会上联合发布了最新的“云上CAE一体机”。
阿里云携手Altair共拓云上工业仿真新机遇
|
8天前
|
机器学习/深度学习 算法 大数据
【BetterBench博士】2024 “华为杯”第二十一届中国研究生数学建模竞赛 选题分析
2024“华为杯”数学建模竞赛,对ABCDEF每个题进行详细的分析,涵盖风电场功率优化、WLAN网络吞吐量、磁性元件损耗建模、地理环境问题、高速公路应急车道启用和X射线脉冲星建模等多领域问题,解析了问题类型、专业和技能的需要。
2522 18
【BetterBench博士】2024 “华为杯”第二十一届中国研究生数学建模竞赛 选题分析
|
8天前
|
机器学习/深度学习 算法 数据可视化
【BetterBench博士】2024年中国研究生数学建模竞赛 C题:数据驱动下磁性元件的磁芯损耗建模 问题分析、数学模型、python 代码
2024年中国研究生数学建模竞赛C题聚焦磁性元件磁芯损耗建模。题目背景介绍了电能变换技术的发展与应用,强调磁性元件在功率变换器中的重要性。磁芯损耗受多种因素影响,现有模型难以精确预测。题目要求通过数据分析建立高精度磁芯损耗模型。具体任务包括励磁波形分类、修正斯坦麦茨方程、分析影响因素、构建预测模型及优化设计条件。涉及数据预处理、特征提取、机器学习及优化算法等技术。适合电气、材料、计算机等多个专业学生参与。
1525 15
【BetterBench博士】2024年中国研究生数学建模竞赛 C题:数据驱动下磁性元件的磁芯损耗建模 问题分析、数学模型、python 代码
|
4天前
|
存储 关系型数据库 分布式数据库
GraphRAG:基于PolarDB+通义千问+LangChain的知识图谱+大模型最佳实践
本文介绍了如何使用PolarDB、通义千问和LangChain搭建GraphRAG系统,结合知识图谱和向量检索提升问答质量。通过实例展示了单独使用向量检索和图检索的局限性,并通过图+向量联合搜索增强了问答准确性。PolarDB支持AGE图引擎和pgvector插件,实现图数据和向量数据的统一存储与检索,提升了RAG系统的性能和效果。
|
10天前
|
编解码 JSON 自然语言处理
通义千问重磅开源Qwen2.5,性能超越Llama
击败Meta,阿里Qwen2.5再登全球开源大模型王座
596 14
|
1月前
|
运维 Cloud Native Devops
一线实战:运维人少,我们从 0 到 1 实践 DevOps 和云原生
上海经证科技有限公司为有效推进软件项目管理和开发工作,选择了阿里云云效作为 DevOps 解决方案。通过云效,实现了从 0 开始,到现在近百个微服务、数百条流水线与应用交付的全面覆盖,有效支撑了敏捷开发流程。
19283 30
|
10天前
|
人工智能 自动驾驶 机器人
吴泳铭:AI最大的想象力不在手机屏幕,而是改变物理世界
过去22个月,AI发展速度超过任何历史时期,但我们依然还处于AGI变革的早期。生成式AI最大的想象力,绝不是在手机屏幕上做一两个新的超级app,而是接管数字世界,改变物理世界。
498 49
吴泳铭:AI最大的想象力不在手机屏幕,而是改变物理世界
|
1月前
|
人工智能 自然语言处理 搜索推荐
阿里云Elasticsearch AI搜索实践
本文介绍了阿里云 Elasticsearch 在AI 搜索方面的技术实践与探索。
18845 20
|
1月前
|
Rust Apache 对象存储
Apache Paimon V0.9最新进展
Apache Paimon V0.9 版本即将发布,此版本带来了多项新特性并解决了关键挑战。Paimon自2022年从Flink社区诞生以来迅速成长,已成为Apache顶级项目,并广泛应用于阿里集团内外的多家企业。
17530 13
Apache Paimon V0.9最新进展
|
3天前
|
云安全 存储 运维
叮咚!您有一份六大必做安全操作清单,请查收
云安全态势管理(CSPM)开启免费试用
368 4
叮咚!您有一份六大必做安全操作清单,请查收