Go 语言类型转换
类型转换用于将一种数据类型的变量转换为另外一种类型的变量。
Go 语言类型转换基本格式如下:
type_name(expression)
type_name 为类型,expression 为表达式。
数值类型转换
将整型转换为浮点型:
varaint=10varbfloat64=float64(a)
以下实例中将整型转化为浮点型,并计算结果,将结果赋值给浮点型变量:
packagemainimport"fmt"funcmain(){varsumint=17varcountint=5varmeanfloat32mean=float32(sum)/float32(count)fmt.Printf("mean 的值为: %f\n",mean)}
以上实例执行输出结果为:
mean 的值为: 3.400000
字符串类型转换
将一个字符串转换成另一个类型,可以使用以下语法:
var str string = "10" var num int num, _ = strconv.Atoi(str)
以上代码将字符串变量 str 转换为整型变量 num。
注意, strconv.Atoi 函数返回两个值,第一个是转换后的整型值,第二个是可能发生的错误,我们可以使用空白标识符 _ 来忽略这个错误
。以下实例将字符串转换为整数
packagemainimport("fmt""strconv")funcmain(){str:="123"num,err:=strconv.Atoi(str)iferr!=nil{fmt.Println("转换错误:",err)}else{fmt.Printf("字符串 '%s' 转换为整数为:%d\n",str,num)}}
以上实例执行输出结果为:
字符串 '123' 转换为整数为:123
以下实例将整数转换为字符串:
packagemainimport("fmt""strconv")funcmain(){num:=123str:=strconv.Itoa(num)fmt.Printf("整数 %d 转换为字符串为:'%s'\n",num,str)}
以上实例执行输出结果为:
整数 123 转换为字符串为:'123'
以下实例将字符串转换为浮点数:
packagemainimport("fmt""strconv")funcmain(){str:="3.14"num,err:=strconv.ParseFloat(str,64)iferr!=nil{fmt.Println("转换错误:",err)}else{fmt.Printf("字符串 '%s' 转为浮点型为:%f\n",str,num)}}
以上实例执行输出结果为:
字符串 '3.14' 转为浮点型为:3.140000
以下实例将浮点数转换为字符串:
packagemainimport("fmt""strconv")funcmain(){num:=3.14str:=strconv.FormatFloat(num,'f',2,64)fmt.Printf("浮点数 %f 转为字符串为:'%s'\n",num,str)}
以上实例执行输出结果为:
浮点数 3.140000 转为字符串为:'3.14'
接口类型转换
接口类型转换有两种情况 :类型断言 和 类型转换 。
类型断言
类型断言用于将接口类型转换为指定类型,其语法为:
value.(type) 或者 value.(T)
其中 value 是接口类型的变量,type 或 T 是要转换成的类型。
如果类型断言成功,它将返回转换后的值和一个布尔值,表示转换是否成功。
packagemainimport"fmt"funcmain(){variinterface{}="Hello, World"str,ok:=i.(string)ifok{fmt.Printf("'%s' is a string\n",str)}else{fmt.Println("conversion failed")}}
以上实例中,我们定义了一个接口类型变量 i,并将它赋值为字符串 "Hello, World"。然后,我们使用类型断言将 i 转换为字符串类型,并将转换后的值赋值给变量 str。最后,我们使用 ok 变量检查类型转换是否成功,如果成功,我们打印转换后的字符串;否则,我们打印转换失败的消息。
类型转换
类型转换用于将一个接口类型的值转换为另一个接口类型,其语法为:
T(value)
T 是目标接口类型,value 是要转换的值。
在类型转换中,我们必须保证要转换的值和目标接口类型之间是兼容的,否则编译器会报错。
packagemainimport"fmt"// 定义一个接口 WritertypeWriterinterface{Write([]byte)(int,error)}// 实现 Writer 接口的结构体 StringWritertypeStringWriterstruct{strstring}// 实现 Write 方法func(sw*StringWriter)Write(data[]byte)(int,error){sw.str+=string(data)returnlen(data),nil}funcmain(){// 创建一个 StringWriter 实例并赋值给 Writer 接口变量varw Writer=&StringWriter{}// 将 Writer 接口类型转换为 StringWriter 类型sw:=w.(*StringWriter)// 修改 StringWriter 的字段sw.str="Hello, World"// 打印 StringWriter 的字段值fmt.Println(sw.str)}
解析:
-
定义接口和结构体 :
-
Writer接口定义了Write方法。 -
StringWriter结构体实现了Write方法。
-
-
类型转换 :
-
将
StringWriter实例赋值给Writer接口变量w。 -
使用
w.(*StringWriter)将Writer接口类型转换为StringWriter类型。
-
将
-
访问字段 :
-
修改
StringWriter的字段str,并打印其值。
-
修改
空接口类型
空接口 interface{} 可以持有任何类型的值。在实际应用中,空接口经常被用来处理多种类型的值。
packagemainimport("fmt")funcprintValue(vinterface{}){switchv:=v.(type){caseint:fmt.Println("Integer:",v)casestring:fmt.Println("String:",v)default:fmt.Println("Unknown type")}}funcmain(){printValue(42)printValue("hello")printValue(3.14)}
在这个例子中,printValue 函数接受一个空接口类型的参数,并使用类型断言和类型选择来处理不同的类型。