(1) Golang中数值类型转换,不管是从高精度到低精度还是低精度到高精度,都需要显示转换。
如:
var i int = 42
var f float64 = float64(i)
var u uint = uint(f)
或者,更简洁的形式:
i := 42
f := float64(i)
u := uint(f)
(2) 类型转换,==被转换的是变量存储的数据(值),变量本身的数据类型没有变化==。
package main
import (
"fmt"
"math"
)
func main() {
var x, y int = 3, 4
var f float64 = math.Sqrt(float64(x*x + y*y))
var z uint = uint(f) //改变f对应值的类型,从float64 -> uint
//fmt.Println(x, y, z)
fmt.Printf("f=%T\n",f)
fmt.Printf("x=%T y=%T z=%T",x,y,z)
}
输出结果:
可以看出来,只是改变了f对应的值的类型,但实际上f的数据类型没有改变。
(3)在转换过程中,比如将int64转换为int8,不会报错,机器会按溢出处理,输出结果不正确。
package main
import (
"fmt"
)
func main(){
var num1 int64 = 99999
var num2 int8 = int8(num1)
fmt.Println(num1)//输出99999
fmt.Println(num2)//输出-97,不正确
}